一,JDBC概述
JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力。
JDBC API
提供者:sun公司
内容:供程序员调用的接口与类
集成在java.sql和javax.sql包中
DriverManager类
Connection接口
Statement接口
ResultSet接口
DriverManager
提供者:sun公司
作用:载入各种不同的JDBC驱动
JDBC 驱动
提供者:数据库厂商作用:负责连接各种不同的数据库
JDBC工作流程:
与数据库建立连接、执行SQL 语句、处理结果
DriverManager:依据数据库的不同,管理JDBC驱动
Connection :负责连接数据库并担任传送数据的任务
Statement :由 Connection 产生、负责执行SQL语句
ResultSet:负责保存Statement执行后所产生的查询结果
JDBC驱动程序类型
桥连
将对JDBC API的调用,转换为对另一组数据库连接API的调用
优点:可以访问所有ODBC可以访问的数据库
缺点:执行效率低、功能不够强大
纯Java驱动
由JDBC驱动直接访问数据库
优点:100% Java,快速又可跨平台
缺点:访问不同数据库需下载专用的JDBC驱
二, JDBC驱动与连接
驱动程序的加载
使用Class类中的静态方法forName( )来实现
Class.forName(“oracle.jdbc.driver.OracleDriver”);
直接创建一个驱动程序的对象
new oracle.jdbc.driver.OracleDriver( );
使用System类中的静态方法setProperty( )来实现
1. System.setProperty(“jdbc.drivers”, 2. 3. “oracle.jdbc.driver.OracleDriver”)
建立数据库连接(纯Java驱动方式)
下载数据库厂商提供的驱动程序包
将驱动程序包引入工程中
编程,通过纯Java驱动方式与数据库建立连接
//
url代表数据库的资源定位,格式:jdbc:驱动器类型:数据库资源。 String URL=“jdbc:oracle:thin:@localhost:1521:ora"; Class.forName(“oracle.jdbc.driver.OracleDriver"); Connection con = DriverManager.getConnection(URL,“scott",“tiger");
三,事务处理
事务定义
指用户定义的数据库操作序列要么全执行,要么全不执行,事务是不可分割的工作单位。
事务处理的方式
提交事务commit()
回滚事务rollback()
取消事务自动提交模式
setAutoCommit(false)
四,Statement
创建Statement对象
Statement对象主要方法
executeQuery执行查询语句 ,返回ResultSet对象
executeUpdate执行DML语句等
能执行任何语句操作的execute(),返回boolean值,表示语句是否执行成功
由Connection对象创建
stmt=conn.createStatement();
ResultSet rs=stmt.executeQuery(sql);
int i=stmt.executeUpdate(sql);
boolean b=stmt. execute(sql);
五,ResultSet
通常执行一个查询语句后,会返回一个结果集
获取结果集中的数据
通过列名来获取某个字段的数据
通过列的索引(从1开始)获取某个字段的数据
数据类型的转换
日期类型数据的处理
通常在数据库中处理,Oracle中采用的方式:
TO_CHAR(日期,格式字符)
TO_DATE(格式字符)
Null与零数值
NULL是SQL中一个很特殊的值 ,不是数值类型0
表示的是数据库中的某列没有定义任何的数据
ResultSet 提供了测试数据库中某列是否为NULL的方法wasNull()
六,PreparedStatement
PreparedStatement接口继承 Statement接口
PreparedStatement比普通的Statement对象使用起来更加灵活,更有效率。
当 SQL 语句将运行多次时,尽量使用PreparedStatement,以便提高运行效率
七,CallableStatement
调用数据库中的存储过程
创建CallableStatement对象
不带参数的存储过程
CallableStatement cs = conn.preparedCall (“{call存储过程名()}”);
传入IN参数的存储过程
CallableStatement cs = conn.preparedCall (“{call存储过程名(?,?,?)}”);
传入IN或者OUT参数的存储过程
CallableStatement cs = conn.preparedCall (“{? = call存储过程名(?,?,?)}”)