什么是 JDBC:

• JDBC(Java DataBase Connectivity)java 数据库连接

• 是 JavaEE 平台下的技术规范

• 定义了在 Java 语言中连接数据,执行 SQL 语句的标准

• 可以为多种关系数据库提供统一访问

什么是数据库驱动程序:

• 数据库厂商对 JDBC 规范的具体实现

• 不同数据产品的数据库驱动名字有差异

• 在程序中需要依赖数据库驱动来完成对数据库的操作

程序操作数据库流程:

Driver 接口:

Driver 接口的作用是来定义数据库驱动对象应该具备的一些能力。比如与数据库建立连接的方法的定义所有支持 java 语言连接的数据库都实现了该接口,实现该接口的类我们称之为数据库驱动类。在程序中要连接数据库,必须先通过 JDK 的反射机制加载数据库驱动类,将其实例化。不同的数据库驱动类的类名有区别。

加载 MySql 驱动:Class.forName("com.mysql.jdbc.Driver");

加载 Oracle 驱动:Class.forName("oracle.jdbc.driver.OracleDriver");

DriverManager 类:

DriverManager 通过实例化的数据库驱动对象,能够建立应用程序与数据库之间建立连 接。并返回 Connection 接口类型的数据库连接对象。

常用方法:

• getConnection(String jdbcUrl, String user, String password)该方法通过访问数据库的 url、用户以及密码,返回对应的数据库的 Connection 对象。

Connection 接口

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");

常用方法:

• createStatement():创建向数据库发送 sql 的 Statement 接口类型的对象。

• preparedStatement(sql) :创建向数据库发送预编译 sql 的 PrepareSatement 接口类型的对象。

• prepareCall(sql):创建执行存储过程的 CallableStatement 接口类型的对象。

• setAutoCommit(boolean autoCommit):设置事务是否自动提交。

• commit() :在链接上提交事务。

• rollback() :在此链接上回滚事务。

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 值

 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)

获取在数据库里任意类型的数据。

ResultSet 对结果集进行滚动的方法

• next():移动到下一行。

• Previous():移动到前一行。

• absolute(int row):移动到指定行。

• beforeFirst():移动 resultSet 的最前面。

• afterLast() :移动到 resultSet 的最后面。

 CallableStatement 接口

继承自 PreparedStatement 接口,由方法 prepareCall 创建,用于调用数据库的存储过程。

JDBC 的使用

加载数据库驱动程序 → 建立数据库连接 Connection → 创建执行 SQL 的语句Statement → 处理执行结果 ResultSet → 释放资源

注册驱动:

Class.forName("com.mysql.jdbc.Driver");

获取连接:

Connection conn =DriverManager.getConnection("jdbc:mysql://localhost: 3306/bjsxt?useUnicode=true&characterEncoding=utf-8", "root", "root");

执行 SQL

String sql="insert into departments values(default,'"+department_name+"'"+location_id+")" ; Statement state = conn.createStatement();

释放资源:

if(state != null){ try { state.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } }if(conn != null){ try { conn.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } }

最新文章

  1. Ruby字符串
  2. t4 加载文件到解决方案
  3. 【Arduino】使用C#实现Arduino与电脑进行串行通讯
  4. linux ssh 使用深度解析(key登录详解)
  5. hibernate对象关系实现(三)多对多实现
  6. 15、SQL基础整理(视图)
  7. SpringMVC的各种参数绑定方式
  8. 理解Linux系统负荷[转]
  9. HDU 3271-SNIBB(数位dp)
  10. Linux 安装配置 JDK 8
  11. C#应用程序中读取Oracle数据库
  12. linux 下搭建 ftp
  13. Java编程学习技巧和方法总结
  14. Linux安装mongodb总结
  15. Javascript学习二---DOM元素操作
  16. 【转载】访问IIS中网站出现 403.14 - Forbidden报错信息
  17. Cordova/Ionic开发的Android APP启用Chrome Inspect调试的方法
  18. [模式匹配] AC 自动机 模式匹配
  19. day 100天 VUE 父子传值,单页面.
  20. Android Intent Scheme URLs攻击

热门文章

  1. 算法编程题积累(4)——腾讯笔试"有趣的数字“问题
  2. nginx跨域解决方案
  3. php charles 使用方法
  4. php查询字符串的函数
  5. Ember.js和Vue.js对比,哪个框架更优秀?
  6. python模块——psutil
  7. java 实现一个死锁
  8. springMvc 通过url传值,实现访问
  9. 0MQ讲述多线程魔法
  10. 利用Python学习线性代数 -- 1.1 线性方程组