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、关闭连接对象 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JDBC (Java Database Connectivity) 是一种用于Java应用程序访问数据库的标准API。查询数据库的基本流程如下: 1. **加载驱动**:首先,需要通过Class.forName()方法加载对应数据库的JDBC驱动程序,例如`Class.forName("com.mysql.jdbc.Driver")`。 2. **创建连接**:使用DriverManager.getConnection()方法或ConnectionPool获取到数据库连接,通常需要提供数据库URL、用户名和密码作为参数。 ```java String url = "jdbc:mysql://localhost:3306/mydatabase"; String user = "username"; String password = "password"; Connection conn = DriverManager.getConnection(url, user, password); ``` 3. **声明游标**:如果使用的是预编译语句(PreparedStatement),可以避免SQL注入攻击,并提高性能,因为数据库会只解析一次SQL。 4. **编写SQL查询**:构建SQL查询字符串或使用PreparedStatement。例如,简单的SELECT查询: ```java String sql = "SELECT * FROM users WHERE id = ?"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setInt(1, userId); ``` 5. **执行查询**:调用PreparedStatement的executeQuery()方法执行SQL,得到ResultSet对象,它包含了查询结果。 6. **处理结果集**:遍历ResultSet,通过其提供的getXXX()方法获取每一列的值,如`rs.getString("name")`。 7. **关闭资源**:在完成操作后,记得关闭ResultSet、PreparedStatement以及Connection以释放系统资源。 ```java try { ResultSet rs = pstmt.executeQuery(); // ... 处理结果集 } finally { if (rs != null) rs.close(); if (pstmt != null) pstmt.close(); if (conn != null) conn.close(); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值