JDBC流程

1、 加载 JDBC 驱动程序:  

在连接数据库之前,首先要加载想要连接的数据库的驱动到 JVM(Java 虚 拟机),  这通过 java.lang.Class 类的静态方法 forName(String className)实现。

 2、 提供 JDBC 连接的 URL

 
连接 URL 定义了连接数据库时的协议、子协议、数据源标识。  - 书写形式:协议:子协议:数据源标识 
协议:在 JDBC 中总是以 jdbc 开始 子协议:是桥连接的驱动程序或是数据 库管理系统名称。  数据源标识:标记找到数据库来源的地址与连接端口。  


3、创建数据库的连接  

要连接数据库,需要向 java.sql.DriverManager 请求并获得 Connection 对 象, 该对象就代表一个数据库的连接。  - 使用 DriverManager 的 getConnectin(String url , String username , String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和 密码来 获得。

4、 创建一个 Statement  


要执行 SQL 语句,必须获得 java.sql.Statement 实例,Statement 实例分为 以下 3 种类型:

 1、执行静态 SQL 语句。通常通过 Statement 实例实现。  

 2、执行动态 SQL 语句。通常通过 PreparedStatement 实例实现。

 3、执行数据库存储过程。通常通过 CallableStatement 实例实现。

 具体的实现方式:  

Statement stmt = con.createStatement() ; PreparedStatement pstmt =

con.prepareStatement(sql) ; CallableStatement cstmt =

con.prepareCall(“{CALL demoSp(? , ?)}”) ;  

5、执行 SQL 语句  


Statement 接口提供了三种执行 SQL 语句的方法:executeQuery 、 executeUpdate 和 execute  

1、ResultSet executeQuery(String sqlString):执行查询数据库的 SQL 语句 , 返回一个结果集(ResultSet)对象。

 2、int executeUpdate(String sqlString):用于执行 INSERT、UPDATE 或 DELETE 语句以及 SQL DDL 语句,如:CREATE TABLE 和 DROP TABLE 等  

3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的 语 句。 具体实现的代码:

 ResultSet rs = stmt.executeQuery(“SELECT * FROM …”) ; int rows = 
stmt.executeUpdate(“INSERT INTO …”) ; boolean flag = stmt.execute(String sql) ;    

6、处理结果  


两种情况:  
1、执行更新返回的是本次操作影响到的记录数。

 2、执行查询返回的结果是一个 ResultSet 对象。  

• ResultSet 包含符合 SQL 语句中条件的所有行,并且它通过一套 get 方法 提供了对这些 行中数据的访问。

 • 使用结果集(ResultSet)对象的访问方法获取数据:

 while(rs.next()){

 String name = rs.getString(“name”) ;  

String pass = rs.getString(1) ; // 此方法比较高效

 }  

(列是从左到右编号的,并且从列 1 开始)

 
7、关闭 JDBC 对象  


操作完成以后要把所有使用的 JDBC 对象全都关闭,以释放 JDBC 资源, 关闭顺序和声 明顺序相反:

 1、关闭记录集  

 2、关闭声明  

 3、关闭连接对象 


版权声明:本文为weixin_44033440原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。