2022.3.10 jdbc

JDBC中,Driver接口定义了数据库驱动的能力,DriverManager管理数据库驱动并建立连接。JDBCURL用于指定数据库连接。Connection接口代表数据库连接,提供执行SQL的方法。Statement用于执行静态SQL,PreparedStatement用于预编译和参数化SQL,提高效率且防止SQL注入。ResultSet接口存储查询结果,提供遍历数据的方法。
摘要由CSDN通过智能技术生成
1.JBDC 中常用的类与接口
1
1)Driver 接口
Driver 接口的作用是来定义数据库驱动对象应该具备的一些能 力。比如与数据库建立连 接的方法的定义,该接口是提供给数据库厂商使用的,所有支持 java 语言连接的数据库都实现了该接口,实现该接口的类我们称 之为数据库驱动类。
2
2)DriverManager
DriverManager 是驱动程序管理器,是负责管理数据库驱动程序 的。驱动注册以后,会保存在DriverManager 中的已注册列表 中。 DriverManager 通过实例化的数据库驱动对象,能够建立
应用程序与数据库之间建立连 接。并返回 Connection 接口类型 的数据库连接对象。getConnection(String jdbcUrl, String user, String password)该方法通过访问数据库的 url 、用户以及密码,返回对应的数 据库的 Connection 对象。
3)JDBC URL
与数据库连接时,用来连接到指定数据库标识符。在 URL
包括了该数据库的类型、 地址、端口、库名称等信息。不同
品牌数据库的连接 URL 不同。
连接 MySql 数据库:
Connection conn = DriverManager . getConnection ( "jdbc:mys ql://host:port/database" , "user" , "password" );
3)Connection 接口
Connection 是数据库的连接(会话)对象。对数据库的一切操
作都是在这个连接基础之上进行的,我们可以通过该对象执行
sql 语句并返回结果。
Connection conn =
DriverManager . getConnection ( "jdbc:mys
ql://host:port/database" , "user" ,
"password" );
1
Connection conn =
DriverManager . getConnection ( "jdbc:ora
cle:thin:@host:port:database" ,
"user" , "password" );
1
4) 常用方法
createStatement()
创建向数据库发送 sql Statement 接口类型的对象。
preparedStatement(sql)
创建向数据库发送预编译 sql PrepareSatement 接口类型
的对象。
setAutoCommit(boolean autoCommit)
设置事务是否自动提交。
commit()
在链接上提交事务。
rollback()
在此链接上回滚事务。
4
Statement 接口
用于执行静态 SQL 语句并返回它所生成结果的对象。 由
createStatement 创建,用于发送简单的 SQL 语句(不支持动
态绑定)。
常用方法
execute(String sql)
执行参数中的 SQL ,返回是否有结果集。
executeQuery(String sql)
运行 select 语句,返回 ResultSet 结果集。
executeUpdate(String sql)
运行 insert/update/delete 操作,返回更新的行数。
addBatch(String sql)
把多条 sql 语句放到一个批处理中。
executeBatch()
向数据库发送一批 sql 语句执行。
PreparedStatement 接口
继承自 Statement 接口,由 preparedStatement 创建,用于发
送含有一个或多个参数的 SQL 语句。 PreparedStatement 对象
Statement 对象的效率更高,由于实现了动态的参数绑定,
所以可以防止 SQL 注入,所以我们一般都使用
PreparedStatement
常用方法
addBatch()
把当前 sql 语句加入到一个批处理中。
execute()
执行当前 SQL ,返回个 boolean
executeUpdate()
运行 insert/update/delete 操作,返回更新的行数。
executeQuery()
执行当前的查询,返回一个结果集对象
setDate(int parameterIndex, Date x)
向当前 SQL 语句中的指定位置绑定一个 java.sql.Date
setDouble(int parameterIndex, double x)
向当前 SQL 语句中的指定位置绑定一个 double
setFloat(int parameterIndex, float x)
向当前 SQL 语句中的指定位置绑定一个 float
setInt(int parameterIndex, int x)
向当前 SQL 语句中的指定位置绑定一个 int
setString(int parameterIndex, String x)
向当前 SQL 语句中的指定位置绑定一个 String
6
ResultSet 接口
ResultSet 用来暂时存放数据库查询操作获得结果集。
常用方法
getString(int index) getString(String columnName)
获得在数据库里是 varchar char 等类型的数据对象。
getFloat(int index) getFloat(String columnName)
获得在数据库里是 Float 类型的数据对象。
getDate(int index) getDate(String columnName)
获得在数据库里是 Date 类型的数据。
getBoolean(int index) getBoolean(String columnName)
获得在数据库里是 Boolean 类型的数据。
getObject(int index) getObject(String columnName)
获取在数据库里任意类型的数据。
2 JDBC 编写步骤

 

3JDBC中三种Statement对象

Statement:用于执行静态 SQL 语句。

PreparedStatement:用于执行预编译SQL语句。

CallableStatement :用于执行数据库存储过程。
4ResultSet 接口的特点
ResultSet 用来存放数据库查询操作获得结果集,通过对 ResultSet的操作可以获取查询到的结果集数据。
ResultSet 对象具有指向其当前数据行的指针。最初,指针被置于第一行之前。 next 方法将指针移
动到下一行;因为该方法在 ResultSet 对象中没有下一行时返回 false ,所以可以在 while 循环中使
用它来迭代结果集。
默认的 ResultSet 对象仅有一个向前移动的指针。因此,只能迭代它一次,并且只能按从第一行到最后一行的顺序进行。
ResultSet 接口提供用于获取当前行检索列值的获取方法( getBoolean getLong 等)。可以使用
列的索引位置或列的名称检索值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值