版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1,基于WEB的JAVA开发设计 - JDBC数据库访问,2,主要内容,JDBC简介 JDBC驱动程序类型 JDBC基本编程 JDBC高级编程,3,JDBC简介,JDBC(Java Database Connectivity)是一组用来按照统一方式访问数据库的API。 它向程序员提供了独立于数据库的统一接口,可以使开发人员不必考虑所用的特定数据库便可编写应用程序,实现了Java与数据库的互连。 它能够: 提供对数据库的跨平台存取 无需知道数据库具体的位置 无需要知道数据库实现的具体细节,4,5,JDBC驱动程序类型,6,TYPE 1,TYPE 1驱动程序: 是JDBCODBC桥连接方式 通常运
2、行在Windows系统上 需要在客户机上安装ODBC驱动程序,7,TYPE 2,TYPE 2驱动程序: 需要在客户机上安装所用数据对应的本地驱动(这些驱动通常是C或C+语言所编写的)。 该驱动将JDBC对数据库的调用转换成数据库本地的API调用,8,TYPE 3,9,TYPE 3,网络服务可以采用多种技术来提高系统性能,这些服务包括: 负载均衡 缓存技术 连接池技术 容错机制,10,TYPE 4,TYPE 4是一种纯Java的驱动实现,他不需要任何客户端配置。 这也是最为常见的数据库连接方式,11,12,DriverManager,DriverManager类 DriverManager(驱动
3、程序管理器)类负责管理JDBC驱动程序。在使用JDBC驱动程序之前,必须先将驱动程序加载并向DriverManager注册后才可使用,在程序中可以通过调用Class.forName()方法来完成。 常用方法如下: Public static synchronized Connection getConnection(String url,String user,String password) throws SQLException 获得url对应数据库的一个连接 Public static void setLoginTimeout(int seconds) 设置要进行数据库登录时驱动程序等待
4、的延迟时间,13,Connection,Connection接口 Connection对象是通过DriverManager.getConnection()方法获得,代表与数据库的连接,也就是在已经加载的驱动程序和数据库之间建立连接。Connection接口是JSP编程中使用最频繁的接口之一。 常用方法如下: Statement createStatement() throws SQLException 创建一个Statement对象 PrepareStatement prepareStatement(String sql) throws SQLException 创建一个Preparestat
5、ement对象,并能把SQL语句提交到数据库进行预编译 void setAutoCommit(Boolean autocommit) throws SQLException 设置事务提交的模式 void commit() throws SQLException 提交对数据库的更改,使更改生效 void rollback() throws SQLException 放弃当前事务开始以来对数据库所作的修改,14,Statement,Statement接口 Statement用来执行静态SQL语句。例如,执行insert、update、delete语句,可以调用executeUpdate(Strin
6、g sql)方法,执行select语句可以调用executeQuery(String sql)方法,该方法返回ResultSet对象。 常用方法如下: ResultSet executeQuery(String sql) throws SQLException 执行一个查询语句并返回结果集 int executeUpdate(String sql) throws SQLException 执行更新操作,返回更新的行数 Boolean execute(String sql) throws SQLException 执行更新或查询语句,返回是否有结果集,15,PreparedStatement,P
7、reparedStatement接口 PreparedStatement接口继承Statement接口,作为提高性能的一条措施,PreparedStatement提供了可以与查询信息一起预编译的一种语句类型,16,CallableStatement,CallableStatement是JDBC用来调用数据库中存储过程的机制 具体的使用和PreparedStatement相似 需要注意的是:要调用的存储过程必须在数据库中存在,否则将抛出异常,17,ResultSet,ResultSet接口 在Statement执行SQL查询语句时,会返回ResultSet查询结果记录集。ResultSet接口提
8、供了逐行访问这些记录的方法。 常用方法如下: Boolean next() throws SQLException 把当前指针定位到下一行。注意,最初,ResultSet的指针位于第一行之前。 void close() throws SQLException 释放ResultSet对象资源 ResultSet提供了getXXX()方法,用于获取当前行中某列的值,其中“XXX”与列的数据类型有关,例如,如要获取的列是String类型,则使用getString()方法获取该列的值。getXXX()方法如下所示: getString() getInt() getFloat() getDouble()
9、 getDate() getBoolean(,18,19,import java.sql.* Try Class.forName(oracle.jdbc.driver.OracleDriver); String oraURL= “jdbc:oracle:thin:host:port:dbName”; Connection con=DriverManager.getConnection(oraURL, username,password); Statement statement =connection.createStatement(); String query = SELECT name,
10、 pwd FROM sometable; ResultSet resultSet= statement.executeQuery(query); while(resultSet.next() name =resultSet.getString(1); phone =resultSet.getString(2); System.out.println(name+,+phone); resultSet.close(); statement.close(); con.close(); catch(SQLException e,第一步,第二步,第三步,第四步,第五步,第六步,第七步,20,连接数据库的
11、典型步骤,第一步:加载正确的数据库驱动程序 为什么要加载 如何加载 Class.forName(oracle.jdbc.driver.OracleDriver); DriverManager.registerDriver( new oracle.jdbc.driver.OracleDriver(); 经过以上其中之一语句的声明后,驱动程序就会自动地加载。 注意:如果classpath路径中没有找到所需的驱动程序则会抛出 ClassNotFoundException异常,21,第二步,定义所要连接数据库的地址 String ODBCURL“jdbc:odbc:dbName”; String or
12、acleURL= jdbc:oracle:thin:host:port:dbName“; String mysqlURL= jdbc:mysql:/ host:port/dbName“; String sqlURL“jdbc:microsoft:sqlserver:/host:1433;DatabaseName=dbName”; 通过此步骤,定义要连接的数据库资源 不同数据库连接的地址不同,这点需要特别注意,对弈一些常见的数据库连接地址,要求大家能够掌握。 URL由3部分组成,各个部分用冒号间隔,格式如下:jdbc: JDBC URL的3部分可分解如下: jdbc:JDBC中的协议就是jdbc
13、。 :数据库驱动程序名或数据库连接机制的名称。子协议的典型示例为oracle,它用于连接oracle数据库。 :一种标记数据库的方法。子名称根据子协议的不同而不同,使用子名称的目的是为定位数据库 例如 jdbc:oracle:thin:ip:port:sid,22,第三步,建立与数据库的连接 String username = jay_debesee; String password = secret; Connection connection = DriverManager.getConnection(oracleURL, username, password); 通过此步获得与数据库服务
14、器的连接 另外,数据库连接还可以使用连接属性信息,如下: Properties dbprops= new Properties(); dbprops.put(user, sa); dbprops.put(password, ); dbprops.put(server, DEMO); dbprops.put(“db, myDB); try Class.forName(weblogic.jdbc.mssqlserver4.Driver); Connectionconn= DriverManager.getConnection(jdbc:weblogic:mssqlserver4, dbprops)
15、; catch(Exception e,23,第四步,创建语句对象 Statement statement = connection.createStatement(); 第五步,声明SQL语句,并将该语句通过Statement对象提交给服务器进行执行。 Stringsql= “SELECT * FROM ONTACT_TABLE”; ResultSet resultSet=statement.executeQuery(sql); 该语句将sql命令提交给数据库服务器进行执行,并将执行结果存储在ResultSet对象中进行执行,24,Statement接口主要有如下三个方法: 1. Resul
16、tSet executeQuery(String sql) 用于执行查询语句,返回 ResultSet结果集(一个二维表) 2. int executeUpdate(String sql) 用于执行添加、删除或修改操作,返回被更新记录的条数 3. boolean execute(String sql) 执行参数部分的SQL语句; 当SQL语句的执行结果是一个ResultSet结果集时,本方法返回true;并可以通过StatementgetResultSet()方法得到返回的结果集 当SQL语句执行后没有返回的结果集时,该方法返回false,25,第六步:对查询结果进行分析 while(resu
17、ltSet.next() name =resultSet.getString(1); phone =resultSet.getString(2); System.out.println(name+,+phone); 针对不同的类型调用不同的getXxx方法(getString(col), getDate(col), ) 通过指定列名或相对顺序的方式调用getXxx()方法对应列的内容获取出来(getString(String) 对结果集中的内容进行修改(updateString(col,val), ) 可以通过(first(), last(), previous(), next(), abso
18、lute(int), ) 方法浏览可滚动结果集中的内容 支持多个结果集,26,Java数据类型和SQL数据类型之间的映射关系,27,第七步,关闭打开的资源 resultSet.close(); statement.close(); connection.close(); 将打开的资源关闭。 注意:资源关闭的顺序和打开的顺序恰恰相反,28,JDBC-ODBC桥编程实例(Access数据库,创建Access数据库student,表info,字段id(整型),username(文本),pass(文本),name(文本),age(整型) 具体步骤: 建立ODBC数据源 使用JDBC-ODBC驱动建立数
19、据库连接 插入/增加两条记录 修改一条记录 删除一条记录 查询所有记录,29,info表结构,30,建立ODBC数据源,控制面板管理工具数据源 (ODBC)系统DSN添加Microsoft Access Driver(*.mdb)数据源名student,选择刚才所创建的数据库,31,程序代码增加,32,程序代码修改,33,程序代码删除,34,程序代码查询,); rs.close(); stmt.close(); con.close(); ,35,JDBC访问Oracle数据库,打开Oracle的“企业管理器”,为scott用户添加DBA权限。然后在scott中建立一个表table1,该表的结构
20、包括三个字段:name(varchar2)、sex(varchar2)、score(number)。 创建成功后,在该表中插入几条测试数据: 分别为: aaam66 bbbm73 cccf91 dddm85,36,部署Oracle驱动程序,在 “Oracle安装目录/jdbc/lib/” 下找到所需的驱动程序classes12.jar,并将其拷贝到当前应用的 “/WEB-INF/lib” 目录下 然后重新启动tomcat服务,37,一个JDBC访问Oracle 数据库的例子,38,); rs.close(); stmt.close(); con.close(); ,39,连接MySQL数据库和
21、连接Oracle数据库的方法非常类似。只是有两个地方需要注意一下 1). 需要把MySQL的驱动程序mysql-connector-java-5.0.4-bin.jar部署到“/WEB-INF/lib/”下。(MySQL驱动程序可以从其官方网站上下载,连接MySQL数据库,40,2). 注册驱动程序和获取连接的语句变为: Class.forName(com.mysql.jdbc.Driver); 或者Class.forName(org.gjt.mm.mysql.Driver); Connection con = DriverManager.getConnection (jdbc:mysql:/
22、ip:port/sid,Login,password,密码,用户名,数据库名,IP地址,端口号,连接MySQL数据库,41,例:,MySQL数据库编程实例,42,连接SQL Server数据库同样和连接Oracle数据库相似。有两个地方需要注意一下 1). 需要把SQL Server的驱动程序 mssqlserver.jar msbase.jar msutil.jar 部署到“/WEB-INF/lib/”下。(SQL Server的驱动程序可以从微软的官方网站上下载,连接SQL Server数据库,43,2). 注册驱动程序和获取连接的语句变为: Class.forName(com.micro
23、soft.jdbc.sqlserver.SQLServerDriver); Connection con = DriverManager.getConnection (jdbc:sqlserver:/ip:port;databasename=sid,Login,password,密码,用户名,数据库名,IP地址,端口号,连接SQL Server数据库,44,例:,SQL Server数据库编程实例,45,高级编程部分,在该部分,内容包括: 事务的概念 使用批处理更新 使用PreparedStatement对象 使用CallableStatement对象 处理可滚动的结果集 处理多个结果集 处理
24、元数据 处理BLOB和CLOB 使用事务隔离,46,事务,事务可以将一组SQL语句组成原子操作以保证数据的完整性 默认情况下,JDBC使用auto-commit事务模型 一个使用commit和rollabck的示例: Connection con = null; try Class.forName(COM.cloudscape.core.JDBCDriver); con=DriverManager.getConnection( jdbc:cloudscape:c:/PhoneBook); con.setAutoCommit(false); Statement statement = conne
25、ction.createStatement(); statement.executeUpdate(“UPDATE .”);. mit(); catch(Exception e) if(null != con) con.rollback();,47,批处理更新,批处理更新是同时执行多个语句的机制。 要执行批处理,需要: 按照正常的方式创建一个语句对象 向语句对象中添加多个要执行的SQL语句 执行批处理 示例: Statement stmt = connection.createStatement(); stmt.addBatch(insert into test values(. . .); s
26、tmt.addBatch(insert into test values(. . .); . . . stmt.executeBatch(,48,PreparedStatement,PreparedStatement 就是带有占位符的SQL 语句 数据库对他们事先进行编译,因此,客户端需要做的只是传送占位符位置所需要的数据。 而普通Statement的SQL语句,只有在程序运行时才对他们进行编译 因此PreparedStatement运行的速度更快,49,PreparedStatement,示例1: PreparedStatement stmt = connection.prepareStat
27、ement( insert into test values(?,?); stmt.setString(1,”first value”); stmt.setString(2,”second value”); stmt.executeUpdate(); stmt.setString(2,”new record, with different second value”); stmt.executeUpdate(,50,PreparedStatement,示例2: Connection connection =DriverManager.getConnection(url, user, passw
28、ord); PreparedStatement statement =connection.prepareStatement(UPDATE employees +SET salary = ? +WHERE id = ?); int newSalaries=getSalaries(); int employeeIDs=getIDs(); for(int i=0; iemployeeIDs.length; i+) statement.setInt(1,newSalariesi); statement.setInt(2,employeeIDsi); statement.executeUpdate(,
29、51,CallableStatement,CallableStatement是JDBC用来调用数据库中存储过程的机制 具体的使用和PreparedStatement相似 需要注意的是:要调用的存储过程必须在数据库中存在,否则将抛出异常 示例: CallableStatement stmt=connection.prepareCall( “ CALL GET_BOOKS(?,?) ); stmt.setString(1,”first value”); stmt.setString(2,”second value”); ResultSet books = stmt.execute(,52,可滚动的
30、结果集,可滚动结果集是允许你在结果集中的不同行之间进行任意浏览的ResultSet对象。 具体的操纵方式包括: 使用next()和previous()分别向后和向前跳一行 使用first()或last()方法直接跳到结果集中的第一行或最后一行。 使用absolute(int)方法直接跳到结果集中指定的行 使用relative(int)方法向前或向后跳转指定的行数,53,可滚动的结果集,此外,你还可以使用其他方法: beforeFirst(), afterLast():将游标置于第一行之前或最后一行之后。 isFirst(), isLast(), isBeforeFirst(), isAfter
31、Last(): 告诉你游标是否指向指定的位置。 而beforeFirst() and afterLast()方法告诉你是否还有更多的数据需要处理,54,示例: Statement stmt = connection.createStatement( ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); ResultSet books = stmt.executeQuery(“SELECT * FROM Books”); if(books.last() /this scrolls from the end backwards
32、do /do something with this row while(books.previous(,55,为了使创建的结果集具有可滚动性,在创建Statement对象时需要使用指定的构建函数,该构建函数需要指定两个参数: 支持滚动 ResultSet.TYPE_FORWARD_ONLY (不支持滚动) ResultSet.TYPE_SCROLL_SENSITIVE (支持滚动,当更新时,及时更新结果集中的内容) ResultSet.TYPE_SCROLL_INSENSITIVE (支持滚动,但当数据更新时,并不在本结果集中体现) 支持并发 ResultSet.CONCUR_READ_ON
33、LY (禁用更新) ResultSet.CONCUR_UPDATABLE (允许更新,56,多个结果集,批处理和CallableStatement可能返回多个结果集 你可以使用getResultSet()和getMoreResults()来对结果进行检索 示例: stmt.addBatch(.); . stmt.executeBatch(); do isAnUpdate=false; if(stmt.getUpdateCount() != -1) isAnUpdate=true; /the operation was an update, skip else ResultSet rs = st
34、mt.getResultSet(); /. do something with results while(stmt.getMoreResults() | isAnUpdate); /loop if more results or last operation was an update,57,处理元数据,元数据可以提供一些关于数据库结果的一些信息: 数据库本身的信息 DatabaseMetaData dbmd = connection.getMetaData(); 单表的信息 ResultSet tableRS = connection.getMetaData(). getTables(nu
35、ll,null,”TableName”,null); 结果集的信息 ResultSetMetaData rsmd = resultSet.getMetaData(,58,使用MetaData的例子: Connection connection = null; Class.forName(COM.cloudscape.core.JDBCDriver); connection =DriverManager.getConnection( jdbc:cloudscape:c:/PhoneBook); DatabaseMetaData dbmd = connection.getMetaData(); String version = dbmd.getDriverVersion(); System.out.println(“The driver version is:” + version); ResultSet aTable = dbmd.getTables(null,null,”b%”,null); String table
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 暨南大学《劳动经济学》2021-2022学年第一学期期末试卷
- 品质部IPQC工作总结
- 二零二四年度物联网平台运营合同2篇
- 科学计算语言Julia及MWORKS实践 课件 30-一阶有控倒立摆
- 2024年汽车销售顾问年终总结心得
- 2024保洁个人工作总结
- 老年脊柱手术
- 铁路安检培训
- 道路管理规范
- 躁狂患症护理查房
- DMP后台操作手册
- 《建设工程投标实务》课件
- 2024年生产部年度工作计划(3篇)
- 消防安全工作台账
- 《品牌策划与推广》课件
- 学校节水合同范例
- 《安全知识教育》课件
- 肺癌中医护理方案图文课件
- 安全部经理述职
- 对项目施工管理的总体安排和总体施工组织布置及规划
- (2021更新)国家开放大学电大专科《网络营销与策划》判断题案例分析题题库及答案
评论
0/150
提交评论