第9章 JDBC编程.ppt
LOGO第第第第9 9章章章章JDBCJDBC编程编程编程编程9.1 JDBC基础基础(1)JDBC概述将Java语言和Sql结合的一个很好的编程接口。通用的一般的SQL数据库访问和存储结构。支持基本SQL功能的一个通用低层的应用程序编程接口,在不同的数据库功能模块上提供了一个统一的用户接口。是为Java语言定义的一个SQL调用级(CLI)接口9.1 JDBC基础基础(2)JDBC的结构Java 应用程序JDBC APIJDBC ManagerJDBC Drvier APIJDBC-NetDriverJDBC-ODBCBridge DriverODBC andDB DriverDriver ADriver BPulblishedprotocolProprietaryDatabase accessprotocol。9.1 JDBC基础基础(3)JDBC API的结构9.1 JDBC基础基础(3)JDBC API的结构Java.sql.DriverManager用来装载驱动程序,并且为创建新的数据库联接提供支持。Java.sql.Connection完成对某一指定数据库的联接Java.sql.Statement在一个给定的连接中作为SQL执行声明的容器,他包含了两个重要的子类型。Java.sql.PreparedSatement用于执行预编译的sql声明Java.sql.CallableStatement用于执行数据库中存储过程的调用Java.sql.ResultSet对于给定声明取得结果的途径9.2 JDBC访问数据库访问数据库(1)建立连接指定数据库连接的url,数据源的位置使用DriverManager.getConnection(url);例如:String url“jdbc:odbc:datasource”;Connection conn=DriverManager.getConnection(url);或者:Connection conn=DriverManager.getConnection(String url,String user,String password)9.2 JDBC访问数据库访问数据库(2)查询数据库(Statement)(a)创建StatemeStatement stmt=conn.createStatement();(b)执行查询语句String sql=“select*from customer”ResultSet rs=stmt.executeQuery(sql);executeQuery()一般用于执行一个sql语句,返回一个结果集,execute()方法返回多个结果集,一个Statement对象在同一时间只能打开一个结果集,对第二个结果集的打开隐含着对第一个结果集的关闭.(c)关闭Statement stmt.close()9.2 JDBC访问数据库访问数据库(3)查询数据库(PreparedStatement)(a)创建String sql=“select*from customer where age=?”PreparedStatement pstmt=conn.prepareStatement(sql);(b)执行pstmt.setInt(1,30);ResultSet=pstmt.executeQuery();(c)关闭Pstmt.close();9.2 JDBC访问数据库访问数据库(4)数据类型转换表java类型SQL类型booleanBITbyteTINYINTshortSMALLINTintINTEGERlongBIGINTStringCHAR,VARCHAR,LONGVARCHARbyte arrayBINARY ,VAR BINARYjava.sql.DateDATEjava.sql.TimeTIMEjava.sql.TimestampTIMESTAMP9.2 JDBC访问数据库访问数据库(5)数据的更新包括修改,更新和删除记录,创建和删除表,以及增加和删除列.对应于数据库的insert,update,delete,create,drop等.对数据库的更新操作也是通过Statement对象完成的.不使用executeQuery()方法,使用executeUpdate()方法.executeUpdate的返回值是它影响的记录的行数.