JDBC---理论

什么是JDBC

所谓JDBC,意为java数据库连接 是javaEE平台下的技术规范,定义了在JAVA 平台下的技术规范,定义了在java语言内连接数据,执行sql语句的标准;可以为多种关系的数据库提供统一的访问

什么是数据库驱动程序

  • 是数据库厂商对于JDBC规范的具体实现
  • 不同数据产品的数据库驱动名字之间有差异
  • 在程序内需要依赖数据库驱动来完成对于数据库的操作

需要明确,jdbc只是java连接数据库的一种规范,具体的操作还是需要依赖数据库驱动的

JDBC3.0标准下的常用接口和类

  1. Driver接口
    作用:定义数据库驱动对象应该具备的一些能力,实现这个接口的将其称为数据库驱动类
    在程序内要连接数据库,必须先通过jdk的反射机制加载数据库驱动类,将其实例化
    加载MySQL驱动:Class.forName(“com.mysql.jdbc.Driver”);
    加载Oracle驱动:Class.forName(“oracle.jdbc.driver.OracleDriver”);

  2. DriverManager类
    这个类可以通过实例化的数据库驱动对象,可以建立应用程序和数据库之间的连接。并返回Connection接口类型的数据库连接对象。

    2.1 常用的方法
    getConnection(String jdbcUrl,String user,String password)
    这个方法通过访问数据库的,用户以及密码,返回对应的数据库的Connection对象
    jdbc内 什么是url
    在url内包含了这个数据库的类型,地址,端口,库名陈等信息,是和数据库进行连接时,用于连接到指定的数据库的标识符。

  3. Connection接口
    是和数据库连接的对象,我们可以通过这个对象执行sql语句并返回结果。

连接Mysql数据库:
Connection conn = DriverManager.getConnection("jdbc:mysql://host:port/database", "user", "password"); 
连接 Oracle 数据库:
 Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@host:port:database", "user", "password"); 
连接 SqlServer 数据库: 
Connection conn = DriverManager.getConnection("jdbc:microsoft:sqlserver://host:port; DatabaseName=database", "user", "password");

3.1 常用的方法
• createStatement():创建向数据库发送 sql 的 Statement 接口类型的对象。
• preparedStatement(sql) : 创建向数据库发送预编译sql 的PrepareSatement 接口类型的对象。

  1. Statement接口
    用于执行静态 SQL 语句并返回它所生成结果的对象。 由 createStatement 创建,用于发送简单的 SQL 语句(不支持动态绑定)。

4.1常用方法
• execute(String sql):执行参数中的 SQL,返回是否有结果集。
• executeQuery(String sql):运行 select 语句,返回 ResultSet 结果集。
• executeUpdate(String sql):运行 insert/update/delete 操作,返回更新的行数。
• addBatch(String sql) :把多条 sql 语句放到一个批处理中。
• executeBatch():向数据库发送一批 sql 语句执行。

  1. PreparedStatement 接口
    用于发送含有一个或多个参数的 SQL 语句。PreparedStatement 对象比 Statement 对象的效率更高,并且可以防止 SQL 注入,所以 我们一般都使用 PreparedStatement。
    5.1常用方法
    • 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 值
  2. ResultSet接口
    ResultSet 提供检索不同类型字段的方法。
    6.1常用方法
    • 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) 获取在数据库里任意类型的数据。

JDBC的使用步骤

加载数据库驱动程序 — > 建立数据库连接Connection -->建立执行SQL语句Stament -->处理执行结果resultSet --> 释放资源

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值