Java基础回顾系列-第九天-数据库编程

2024-09-08 15:32

本文主要是介绍Java基础回顾系列-第九天-数据库编程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Java基础回顾系列-第九天-数据库编程

    • 数据库简介
    • 工具包
    • java.sql API 内容
      • 与数据库建立连接
      • 执行SQL语句数据库
      • 检索和更新查询结果
      • SQL类型对应Java类型映射
      • 元数据
      • 异常
    • API方法
      • DriverManager
      • Connection
      • Statement
      • PreparedStatement
      • CallableStatement
      • ResultSet
      • java.sql.Date
      • 批处理、存储过程、事务
    • 示例

数据库简介

针对Java数据库开发的包都在java.sql包下。都是些比较基础的。
详细参见:https://docs.oracle.com/en/java/javase/11/docs/api/java.sql/java/sql/package-summary.html

工具包

  • Apache DbUtils:https://commons.apache.org/proper/commons-dbutils/
  • Hutool:https://gitee.com/loolly/hutool

java.sql API 内容

与数据库建立连接

  • DriverManager class - 与驱动程序建立连接
  • SQLPermission class - 在安全管理器(例如applet)中运行的代码尝试通过安装程序设置日志记录流时提供权限 DriverManager
  • Driverinterface - 提供基于JDBC技术注册和连接驱动程序的API(“JDBC驱动程序”); 通常只由DriverManager班级使用
  • DriverPropertyInfoclass - 提供JDBC驱动程序的属性; 一般用户不使用

执行SQL语句数据库

  • Statement - 用于发送基本的SQL语句
  • PreparedStatement- 用于发送预准备语句或基本SQL语句(派生自Statement)
  • CallableStatement- 用于调用数据库存储过程(派生自PreparedStatement)
  • Connection interface - 提供创建语句和管理连接及其属性的方法
  • Savepoint - 在事务中提供保存点

检索和更新查询结果

  • ResultSet 接口

SQL类型对应Java类型映射

  • Array 接口 - SQL的映射 ARRAY
  • Blob 接口 - SQL的映射 BLOB
  • Clob 接口 - SQL的映射 CLOB
  • Date class - SQL的映射 DATE:java.util.Date转换java.sql.Date
  • NClob 接口 - SQL的映射 NCLOB
  • Ref 接口 - SQL的映射 REF
  • RowId 接口 - SQL的映射 ROWID
  • Struct 接口 - SQL的映射 STRUCT
  • SQLXML 接口 - SQL的映射 XML
  • Time 类 - SQL的映射 TIME
  • Timestamp 类 - SQL的映射 TIMESTAMP
  • Types 类 - 为SQL类型提供常量

元数据

  • DatabaseMetaData interface - 提供有关数据库的信息
  • ResultSetMetaDatainterface - 提供有关ResultSet对象 列的信息
  • ParameterMetaDatainterface - 提供有关PreparedStatement命令 参数的信息

异常

  • SQLException - 当访问数据时出于问题而被大多数方法抛出,而出于其他原因则由某些方法抛出
  • SQLWarning - 抛出以表示警告
  • DataTruncation - 抛出表示数据可能已被截断
  • BatchUpdateException - 抛出表示批量更新中的所有命令都未成功执行

API方法

DriverManager

public static Connection getConnection​(String url, String user, String password) throws SQLException

Connection

Statement createStatement() throws SQLException
PreparedStatement prepareStatement​(String sql) throws SQLException
CallableStatement prepareCall​(String sql) throws SQLExceptionvoid setAutoCommit​(boolean autoCommit) throws SQLException
void setTransactionIsolation​(int level) throws SQLException
void commit() throws SQLException
void rollback() throws SQLException
void close() throws SQLException

Statement

int executeUpdate​(String sql) throws SQLException
ResultSet executeQuery​(String sql) throws SQLException

PreparedStatement

void setString​(int parameterIndex, String x) throws SQLException
void setInt​(int parameterIndex, int x) throws SQLException
void setTime​(int parameterIndex, Time x) throws SQLException
void setClob​(int parameterIndex, Reader reader) throws SQLExceptionResultSet executeQuery() throws SQLException
int executeUpdate() throws SQLException

CallableStatement

ResultSet

boolean next() throws SQLException
boolean last() throws SQLException
String getString​(int columnIndex) throws SQLException
String getString​(String columnLabel) throws SQLException

java.sql.Date

java.sql.Date extends java.util.Date
Java中有两个Date类,一个是java.util.Date通常情况下用它获取当前时间或构造时间,另一个是java.sql.Date是针对SQL语句使用的,它只包含日期而没有时间部分。两个类型的时间可以相互转化。

java.sql包下给出三个与数据库相关的日期时间类型:

  • Date:表示日期,只有年月日,没有时分秒。会丢失时间;
  • Time:表示时间,只有时分秒,没有年月日。会丢失日期;
  • Timestamp:表示时间戳,有年月日时分秒,以及毫秒。

util.Date与sql.Date的相互转换

批处理、存储过程、事务

参见:Java-JDBC调用批处理、存储过程、事务

示例

package com.runoob.test;import java.sql.*;public class MySQLDemo {// JDBC 驱动名及数据库 URLstatic final String JDBC_DRIVER = "com.mysql.jdbc.Driver";  static final String DB_URL = "jdbc:mysql://localhost:3306/RUNOOB";// 数据库的用户名与密码,需要根据自己的设置static final String USER = "root";static final String PASS = "123456";public static void main(String[] args) {Connection conn = null;Statement stmt = null;try{// 注册 JDBC 驱动Class.forName("com.mysql.jdbc.Driver");// 打开链接System.out.println("连接数据库...");conn = DriverManager.getConnection(DB_URL,USER,PASS);// 执行查询System.out.println(" 实例化Statement对象...");stmt = conn.createStatement();String sql;sql = "SELECT id, name, url FROM websites";ResultSet rs = stmt.executeQuery(sql);// 展开结果集数据库while(rs.next()){// 通过字段检索int id  = rs.getInt("id");String name = rs.getString("name");String url = rs.getString("url");// 输出数据System.out.print("ID: " + id);System.out.print(", 站点名称: " + name);System.out.print(", 站点 URL: " + url);System.out.print("\n");}// 完成后关闭rs.close();stmt.close();conn.close();}catch(SQLException se){// 处理 JDBC 错误se.printStackTrace();}catch(Exception e){// 处理 Class.forName 错误e.printStackTrace();}finally{// 关闭资源try{if(stmt!=null) stmt.close();}catch(SQLException se2){}// 什么都不做try{if(conn!=null) conn.close();}catch(SQLException se){se.printStackTrace();}}System.out.println("Goodbye!");}
}

这篇关于Java基础回顾系列-第九天-数据库编程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1148486

相关文章

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Springboot整合Redis主从实践

《Springboot整合Redis主从实践》:本文主要介绍Springboot整合Redis主从的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言原配置现配置测试LettuceConnectionFactory.setShareNativeConnect

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

Java SWT库详解与安装指南(最新推荐)

《JavaSWT库详解与安装指南(最新推荐)》:本文主要介绍JavaSWT库详解与安装指南,在本章中,我们介绍了如何下载、安装SWTJAR包,并详述了在Eclipse以及命令行环境中配置Java... 目录1. Java SWT类库概述2. SWT与AWT和Swing的区别2.1 历史背景与设计理念2.1.