1、Date:2 August 2022基于WEB的JAVA开发设计1基于基于WEBWEB的的JAVAJAVA开发设计开发设计-JDBC-JDBC数据库访问数据库访问Date:2 August 2022基于WEB的JAVA开发设计2主要内容主要内容JDBC简介简介JDBC驱动程序类型驱动程序类型JDBC基本编程基本编程JDBC高级编程高级编程Date:2 August 2022基于WEB的JAVA开发设计3JDBC简介简介JDBC(Java Database Connectivity)是一组用来)是一组用来按照统一方式访问数据库的按照统一方式访问数据库的API。它向程序员提供了它向程序员提供了独立
2、于数据库的统一接口,可以使开发人员不必考虑独立于数据库的统一接口,可以使开发人员不必考虑所用的特定数据库便可编写应用程序,实现了所用的特定数据库便可编写应用程序,实现了Java与与数据库的互连。数据库的互连。它能够:它能够:提供对数据库的跨平台存取提供对数据库的跨平台存取无需知道数据库具体的位置无需知道数据库具体的位置无需要知道数据库实现的具体细节无需要知道数据库实现的具体细节Date:2 August 2022基于WEB的JAVA开发设计4JDBCJava应用应用1OracleMySQL SQL Server Java应用应用nDate:2 August 2022基于WEB的JAVA开发设计
3、5JDBC驱动程序类型驱动程序类型RDBMSJDBC体系结构体系结构JDBC APIJDBC-ODBC桥(桥(Type 1)JDBC-Native(Type 2)JDBC-NET(Type 3)纯纯Java JDBC驱动驱动(Type 4)ODBC 驱动驱动Native API(C/C+)Net Server(JNDI)Date:2 August 2022基于WEB的JAVA开发设计6TYPE 1TYPE 1驱动程序:驱动程序:是是JDBCODBC桥连接方式桥连接方式通常运行在通常运行在Windows系统上系统上需要在客户机上安装需要在客户机上安装ODBC驱动程序驱动程序Date:2 Augu
4、st 2022基于WEB的JAVA开发设计7TYPE 2TYPE 2驱动程序:驱动程序:需要在客户机上安装所用数据对应的本地驱动(这些驱动通需要在客户机上安装所用数据对应的本地驱动(这些驱动通常是常是C或或C+语言所编写的)。语言所编写的)。该驱动将该驱动将JDBC对数据库的调用转换成数据库本地的对数据库的调用转换成数据库本地的API调用调用Date:2 August 2022基于WEB的JAVA开发设计8TYPE 3Date:2 August 2022基于WEB的JAVA开发设计9TYPE 3网络服务可以采用多种技术来提高系统性能,这些服网络服务可以采用多种技术来提高系统性能,这些服务包括:
5、务包括:负载均衡负载均衡缓存技术缓存技术连接池技术连接池技术容错机制容错机制DBMSDate:2 August 2022基于WEB的JAVA开发设计10TYPE 4TYPE 4是一种纯是一种纯Java的驱动实现,他不需要任何客户的驱动实现,他不需要任何客户端配置。端配置。这也是最为常见的数据库连接方式。这也是最为常见的数据库连接方式。Date:2 August 2022基于WEB的JAVA开发设计11Date:2 August 2022基于WEB的JAVA开发设计12DriverManagerDriverManager类类DriverManager(驱动程序管理器驱动程序管理器)类负责管理类负
6、责管理JDBC驱动程序。驱动程序。在使用在使用JDBC驱动程序之前,必须先将驱动程序加载并向驱动程序之前,必须先将驱动程序加载并向DriverManager注册后才可使用,在程序中可以通过调用注册后才可使用,在程序中可以通过调用Class.forName()方法来完成。方法来完成。常用方法如下:常用方法如下:Public static synchronized Connection getConnection(String url,String user,String password)throws SQLException获得获得url对应数据库的一个连接对应数据库的一个连接Public s
7、tatic void setLoginTimeout(int seconds)设置要进行数据库登录时驱动程序等待的延迟时间设置要进行数据库登录时驱动程序等待的延迟时间Date:2 August 2022基于WEB的JAVA开发设计13ConnectionConnection接口接口Connection对象是通过对象是通过DriverManager.getConnection()方法获得,代表与方法获得,代表与数据库的连接,也就是在已经加载的驱动程序和数据库之间建立连接。数据库的连接,也就是在已经加载的驱动程序和数据库之间建立连接。Connection接口是接口是JSP编程中使用最频繁的接口之一
8、。编程中使用最频繁的接口之一。常用方法如下:常用方法如下:Statement createStatement()throws SQLException创建一个创建一个Statement对象对象PrepareStatement prepareStatement(String sql)throws SQLException创建一个创建一个Preparestatement对象,并能把对象,并能把SQL语句提交到数据库进行预编译语句提交到数据库进行预编译void setAutoCommit(Boolean autocommit)throws SQLException设置事务提交的模式设置事务提交的模式
9、void commit()throws SQLException提交对数据库的更改,使更改生效提交对数据库的更改,使更改生效void rollback()throws SQLException放弃当前事务开始以来对数据库所作的修改放弃当前事务开始以来对数据库所作的修改 Date:2 August 2022基于WEB的JAVA开发设计14StatementStatement接口接口Statement用来执行静态用来执行静态SQL语句。例如,执行语句。例如,执行insert、update、delete语句,可以调用语句,可以调用executeUpdate(String sql)方法,执行方法,执行
10、select语句可以调用语句可以调用executeQuery(String sql)方法,该方法返回方法,该方法返回ResultSet对象。对象。常用方法如下:常用方法如下:ResultSet executeQuery(String sql)throws SQLException执行一个查询语句并返回结果集执行一个查询语句并返回结果集int executeUpdate(String sql)throws SQLException执行更新操作,返回更新的行数执行更新操作,返回更新的行数Boolean execute(String sql)throws SQLException执行更新或查询语句,
11、返回是否有结果集执行更新或查询语句,返回是否有结果集 Date:2 August 2022基于WEB的JAVA开发设计15PreparedStatementPreparedStatement接口接口PreparedStatement接口继承接口继承Statement接口,作为提高性接口,作为提高性能的一条措施,能的一条措施,PreparedStatement提供了可以与查询信息提供了可以与查询信息一起预编译的一种语句类型。一起预编译的一种语句类型。Date:2 August 2022基于WEB的JAVA开发设计16CallableStatementCallableStatement是JDBC用
12、来调用数据库中存储过程的机制具体的使用和PreparedStatement相似需要注意的是:要调用的存储过程必须在数据库中存在,否则将抛出异常Date:2 August 2022基于WEB的JAVA开发设计17ResultSetResultSet接口接口在在Statement执行执行SQL查询语句时,会返回查询语句时,会返回ResultSet查询结果记录集。查询结果记录集。ResultSet接口提供了逐行访问这些记录的方法。接口提供了逐行访问这些记录的方法。常用方法如下:常用方法如下:Boolean next()throws SQLException把当前指针定位到下一行。注意,最初,把当前指
13、针定位到下一行。注意,最初,ResultSet的指针位于第一行的指针位于第一行之前。之前。void close()throws SQLException释放释放ResultSet对象资源对象资源ResultSet提供了提供了getXXX()方法,用于获取当前行中某列的值,其中方法,用于获取当前行中某列的值,其中“XXX”与列的数据类型有关,例如,如要获取的列是与列的数据类型有关,例如,如要获取的列是String类型,则类型,则使用使用getString()方法获取该列的值。方法获取该列的值。getXXX()方法如下所示:方法如下所示:getString()getInt()getFloat()g
14、etDouble()getDate()getBoolean()Date:2 August 2022基于WEB的JAVA开发设计18Oracle驱动驱动OracleMYSQLAcessMYSQL驱动驱动JDBCODBC桥桥DriverManagerConnectionPreparedStatementStatementCallableStatementResultSetResultSetResultSet应用层应用层Date:2 August 2022基于WEB的JAVA开发设计19import java.sql.*TryClass.forName(oracle.jdbc.driver.Orac
15、leDriver);String oraURL=“jdbc:oracle:thin:host:port:dbName”;Connection con=DriverManager.getConnection(oraURL,username,password);Statement statement=connection.createStatement();String query=SELECT name,pwd FROM sometable;ResultSet resultSet=statement.executeQuery(query);while(resultSet.next()name=r
16、esultSet.getString(1);phone=resultSet.getString(2);System.out.println(name+,+phone);resultSet.close();statement.close();con.close();catch(SQLException e)第一步第一步第二步第二步第三步第三步第四步第四步第五步第五步第六步第六步第七步第七步Date:2 August 2022基于WEB的JAVA开发设计20连接数据库的典型步骤连接数据库的典型步骤第一步:加载正确的数据库驱动程序第一步:加载正确的数据库驱动程序为什么要加载为什么要加载如何加载如何加
17、载Class.forName(oracle.jdbc.driver.OracleDriver);DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver();经过以上其中之一语句的声明后,驱动程序就会自动地加载。经过以上其中之一语句的声明后,驱动程序就会自动地加载。注意:如果注意:如果classpath路径中没有找到所需的驱动程序则会抛出路径中没有找到所需的驱动程序则会抛出 ClassNotFoundException异常。异常。Oracle驱动驱动OracleMYSQLAcessMYSQL驱动驱动JDBCODBC桥桥Dr
18、iverManagerDate:2 August 2022基于WEB的JAVA开发设计21第二步,定义所要连接数据库的地址第二步,定义所要连接数据库的地址String ODBCURL“jdbc:odbc:dbName”;String oracleURL=jdbc:oracle:thin:host:port:dbName“;String mysqlURL=jdbc:mysql:/host:port/dbName“;String sqlURL“jdbc:microsoft:sqlserver:/host:1433;DatabaseName=dbName”;通过此步骤,定义要连接的数据库资源通过此步
19、骤,定义要连接的数据库资源不同数据库连接的地址不同,这点需要特别注意,对弈一些常见的数据库连不同数据库连接的地址不同,这点需要特别注意,对弈一些常见的数据库连接地址,要求大家能够掌握。接地址,要求大家能够掌握。URL由由3部分组成,各个部分用冒号间隔,格式如下:部分组成,各个部分用冒号间隔,格式如下:jdbc:JDBC URL的的3部分可分解如下:部分可分解如下:jdbc:JDBC中的协议就是中的协议就是jdbc。:数据库驱动程序名或数据库连接机制的名称。子协议的典型示:数据库驱动程序名或数据库连接机制的名称。子协议的典型示例为例为oracle,它用于连接,它用于连接oracle数据库。数据库
20、。:一种标记数据库的方法。子名称根据子协议的不同而不同,使:一种标记数据库的方法。子名称根据子协议的不同而不同,使用子名称的目的是为定位数据库用子名称的目的是为定位数据库例如例如 jdbc:oracle:thin:ip:port:sidDate:2 August 2022基于WEB的JAVA开发设计22第三步,建立与数据库的连接第三步,建立与数据库的连接String username=jay_debesee;String password=secret;Connection connection=DriverManager.getConnection(oracleURL,username,pa
21、ssword);通过此步获得与数据库服务器的连接通过此步获得与数据库服务器的连接另外,数据库连接还可以使用连接属性信息,如下:另外,数据库连接还可以使用连接属性信息,如下:Properties dbprops=new Properties();dbprops.put(user,sa);dbprops.put(password,);dbprops.put(server,DEMO);dbprops.put(“db,myDB);tryClass.forName(weblogic.jdbc.mssqlserver4.Driver);Connectionconn=DriverManager.getCon
22、nection(jdbc:weblogic:mssqlserver4,dbprops);catch(Exception e).Date:2 August 2022基于WEB的JAVA开发设计23第四步,创建语句对象第四步,创建语句对象Statement statement=connection.createStatement();第五步,声明第五步,声明SQL语句,并将该语句通过语句,并将该语句通过Statement对对象提交给服务器进行执行。象提交给服务器进行执行。Stringsql=“SELECT*FROM ONTACT_TABLE”;ResultSet resultSet=stateme
23、nt.executeQuery(sql);该语句将该语句将sql命令提交给数据库服务器进行执行,并将执行结命令提交给数据库服务器进行执行,并将执行结果存储在果存储在ResultSet对象中进行执行。对象中进行执行。Date:2 August 2022基于WEB的JAVA开发设计24Statement接口主要有如下三个方法:接口主要有如下三个方法:1.ResultSet executeQuery(String sql)用于执行用于执行查询语句,返回,返回 ResultSet结果集(一个二维表)结果集(一个二维表)2.int executeUpdate(String sql)用于执行用于执行添加、
24、删除或修改操作,返回被更新记录的条数操作,返回被更新记录的条数3.boolean execute(String sql)执行参数部分的执行参数部分的SQL语句;语句;当当SQL语句的执行结果是一个语句的执行结果是一个ResultSet结果集时,本方法返回结果集时,本方法返回true;并可以通过;并可以通过StatementgetResultSet()方法得到返回的结方法得到返回的结果集果集 当当SQL语句执行后没有返回的结果集时,该方法返回语句执行后没有返回的结果集时,该方法返回falseDate:2 August 2022基于WEB的JAVA开发设计25第六步:对查询结果进行分析第六步:对查
25、询结果进行分析while(resultSet.next()name=resultSet.getString(1);phone=resultSet.getString(2);System.out.println(name+,+phone);针对不同的类型调用不同的针对不同的类型调用不同的getXxx方法方法(getString(col),getDate(col),)通过指定列名或相对顺序的方式调用通过指定列名或相对顺序的方式调用getXxx()方法对应列方法对应列的内容获取出来的内容获取出来(getString(String)对结果集中的内容进行修改对结果集中的内容进行修改(updateStri
26、ng(col,val),)可以通过可以通过(first(),last(),previous(),next(),absolute(int),)方法浏览可滚动结果集中的内容方法浏览可滚动结果集中的内容支持多个结果集支持多个结果集Date:2 August 2022基于WEB的JAVA开发设计26Java数据类型和数据类型和SQL数据类型之间的映射关系数据类型之间的映射关系SQL类型类型Java数据类型数据类型JDBC访问方法访问方法SQL类型类型Java数据类型数据类型JDBC访问方法访问方法bitbooleangetBoolean()DECIMALjava.math.BigDecimalgetB
27、igDecimal()TINYINTbytegetByte()NUMBERICjava.math.BigDecimalgetBigDecimal()SMALLINTshortgetShort()Charjava.lang.StringgetString()INTEGERintgetInt()VARCHARjava.lang.StringgetString()BIGINTlonggetLong()LONGVARCHARjava.lang.StringgetString()REALfloatgetFloat()DATEjava.sql.dategetDate()FLOATdoublegetDoub
28、le()TIMEjava.sql.timegetTime()DOUBLEdoublegetDouble()TIMESTAMPjava.sql.TIMESTAMPgetTimestamp()BINARYbytegetBytes()BLOBjava.sql.BlobgetBlob()VARBINARYbytegetBytes()CLOBjava.sql.ClobgetClob()LONGBINARYbytegetBytes()ARRAYjava.sql.ArraygetArray()REFjava.sql.RefgetRef()STRUCTjava.sql.StructgetSDate:2 Aug
29、ust 2022基于WEB的JAVA开发设计27第七步,关闭打开的资源第七步,关闭打开的资源resultSet.close();statement.close();connection.close();将打开的资源关闭。将打开的资源关闭。注意:资源关闭的顺序和打开的顺序恰恰相反。注意:资源关闭的顺序和打开的顺序恰恰相反。Date:2 August 2022基于WEB的JAVA开发设计28JDBC-ODBC桥编程实例桥编程实例(Access数据库数据库)创建创建Access数据库数据库student,表,表info,字段,字段id(整型整型),username(文本文本),pass(文本文本),
30、name(文本文本),age(整型整型)具体步骤:具体步骤:建立建立ODBC数据源数据源使用使用JDBC-ODBC驱动建立数据库连接驱动建立数据库连接插入插入/增加两条记录增加两条记录修改一条记录修改一条记录删除一条记录删除一条记录查询所有记录查询所有记录Date:2 August 2022基于WEB的JAVA开发设计29info表结构表结构Date:2 August 2022基于WEB的JAVA开发设计30建立建立ODBC数据源数据源控制面板控制面板管理工具管理工具数据源数据源(ODBC)系统系统DSN添加添加Microsoft Access Driver(*.mdb)数据源名数据源名stu
31、dent,选择刚才所创建的,选择刚才所创建的数据库数据库Date:2 August 2022基于WEB的JAVA开发设计31程序代码程序代码增加增加Date:2 August 2022基于WEB的JAVA开发设计32程序代码程序代码修改修改Date:2 August 2022基于WEB的JAVA开发设计33程序代码程序代码删除删除Date:2 August 2022基于WEB的JAVA开发设计34程序代码程序代码查询查询%Class.forName(sun.jdbc.odbc.JdbcOdbcDriver);Connection con=DriverManager.getConnection(
32、jdbc:odbc:student,);Statement stmt=con.createStatement();/查询记录,处理结果集查询记录,处理结果集String sql=select*from info;ResultSet rs=stmt.executeQuery(sql);while(rs.next()out.print(编号:编号:+rs.getString(1);out.print(用户名:用户名:+rs.getString(2);out.print(密码:密码:+rs.getString(3);out.print(姓名:姓名:+rs.getString(name);out.pr
33、int(年龄:年龄:+rs.getFloat(age);out.print();rs.close();stmt.close();con.close();%Date:2 August 2022基于WEB的JAVA开发设计35JDBC访问访问Oracle数据库数据库打开打开Oracle的的“企业管理器企业管理器”,为,为scott用户添加用户添加DBA权限。然后在权限。然后在scott中建立一个表中建立一个表table1,该表,该表的结构包括三个字段:的结构包括三个字段:name(varchar2)、)、sex(varchar2)、)、score(number)。)。创建成功后,在该表中插入几条测
34、试数据:创建成功后,在该表中插入几条测试数据:分别为:分别为:aaam66 bbbm73 cccf91 dddm85Date:2 August 2022基于WEB的JAVA开发设计36部署部署Oracle驱动程序驱动程序在在“Oracle安装目录安装目录/jdbc/lib/”下找到所需的驱动下找到所需的驱动程序程序classes12.jar,并将其拷贝到当前应用的,并将其拷贝到当前应用的“/WEB-INF/lib”目录下目录下然后重新启动然后重新启动tomcat服务服务Date:2 August 2022基于WEB的JAVA开发设计37一个一个JDBC访问访问Oracle数据库的例子数据库的例
35、子Date:2 August 2022基于WEB的JAVA开发设计38%Class.forName(oracle.jdbc.driver.OracleDriver);Connection con=DriverManager.getConnection(“jdbc:oracle:thin:localhost:1521:数据库名数据库名”,“用户名用户名”,“密码密码);Statement stmt=con.createStatement();ResultSet rs=stmt.executeQuery(select*from table1);while(rs.next()out.print(姓名
36、:姓名:+rs.getString(1);out.print(性别:性别:+rs.getString(2);out.print(分数:分数:+rs.getFloat(3);out.print();rs.close();stmt.close();con.close();%Date:2 August 2022基于WEB的JAVA开发设计39连接连接MySQL数据库和连接数据库和连接Oracle数据库的方法非常类似。只数据库的方法非常类似。只是有两个地方需要注意一下是有两个地方需要注意一下1).需要把需要把MySQL的驱动程序的驱动程序mysql-connector-java-5.0.4-bin.j
37、ar部署到部署到“/WEB-INF/lib/”下。(下。(MySQL驱动程序可以驱动程序可以从其官方网站从其官方网站上下载)上下载)连接连接MySQL数据库数据库Date:2 August 2022基于WEB的JAVA开发设计402).注册驱动程序和获取连接的语句变为:注册驱动程序和获取连接的语句变为:Class.forName(com.mysql.jdbc.Driver);或者或者Class.forName(org.gjt.mm.mysql.Driver);Connection con=DriverManager.getConnection(jdbc:mysql:/ip:port/sid,L
38、ogin,password);密码密码用户名用户名数据库名数据库名IP地址地址端口号端口号连接连接MySQL数据库数据库Date:2 August 2022基于WEB的JAVA开发设计41例:例:MySQL数据库编程实例数据库编程实例Date:2 August 2022基于WEB的JAVA开发设计42连接连接SQL Server数据库同样和连接数据库同样和连接Oracle数据库相似。数据库相似。有两个地方需要注意一下有两个地方需要注意一下1).需要把需要把SQL Server的驱动程序的驱动程序mssqlserver.jarmsbase.jarmsutil.jar部署到部署到“/WEB-INF
39、/lib/”下。(下。(SQL Server的驱动程的驱动程序可以从微软的官方网站上下载)序可以从微软的官方网站上下载)连接连接SQL Server数据库数据库Date:2 August 2022基于WEB的JAVA开发设计432).注册驱动程序和获取连接的语句变为:注册驱动程序和获取连接的语句变为:Class.forName(com.microsoft.jdbc.sqlserver.SQLServerDriver);Connection con=DriverManager.getConnection(jdbc:sqlserver:/ip:port;databasename=sid,Login
40、,password);密码密码用户名用户名数据库名数据库名IP地址地址端口号端口号连接连接SQL Server数据库数据库Date:2 August 2022基于WEB的JAVA开发设计44例:例:SQL Server数据库编程实例数据库编程实例Date:2 August 2022基于WEB的JAVA开发设计45高级编程部分高级编程部分在该部分,内容包括:事务的概念使用批处理更新使用PreparedStatement对象使用CallableStatement对象处理可滚动的结果集处理多个结果集处理元数据处理BLOB和CLOB使用事务隔离Date:2 August 2022基于WEB的JAVA开
41、发设计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 st
42、atement=connection.createStatement();statement.executeUpdate(“UPDATE.”);mit();catch(Exception e)if(null!=con)con.rollback();.Date:2 August 2022基于WEB的JAVA开发设计47批处理更新批处理更新批处理更新是同时执行多个语句的机制。批处理更新是同时执行多个语句的机制。要执行批处理,需要:要执行批处理,需要:按照正常的方式创建一个语句对象按照正常的方式创建一个语句对象向语句对象中添加多个要执行的向语句对象中添加多个要执行的SQL语句语句执行批处理执行批处理
43、示例:示例:Statement stmt=connection.createStatement();stmt.addBatch(insert into test values(.);stmt.addBatch(insert into test values(.);.stmt.executeBatch();Date:2 August 2022基于WEB的JAVA开发设计48PreparedStatementPreparedStatement 就是带有占位符的SQL 语句 数据库对他们事先进行编译,因此,客户端需要做的只是传送占位符位置所需要的数据。而普通Statement的SQL语句,只有在程序
44、运行时才对他们进行编译 因此PreparedStatement运行的速度更快。Date:2 August 2022基于WEB的JAVA开发设计49PreparedStatement示例示例1:PreparedStatement stmt=connection.prepareStatement(insert into test values(?,?);stmt.setString(1,”first value”);stmt.setString(2,”second value”);stmt.executeUpdate();stmt.setString(2,”new record,with diff
45、erent second value”);stmt.executeUpdate();Date:2 August 2022基于WEB的JAVA开发设计50PreparedStatement示例示例2:Connection connection=DriverManager.getConnection(url,user,password);PreparedStatement statement=connection.prepareStatement(UPDATE employees +SET salary=?+WHERE id=?);int newSalaries=getSalaries();int
46、 employeeIDs=getIDs();for(int i=0;iemployeeIDs.length;i+)statement.setInt(1,newSalariesi);statement.setInt(2,employeeIDsi);statement.executeUpdate();Date:2 August 2022基于WEB的JAVA开发设计51CallableStatementCallableStatement是JDBC用来调用数据库中存储过程的机制具体的使用和PreparedStatement相似需要注意的是:要调用的存储过程必须在数据库中存在,否则将抛出异常示例:Cal
47、lableStatement stmt=connection.prepareCall(“CALL GET_BOOKS(?,?);stmt.setString(1,”first value”);stmt.setString(2,”second value”);ResultSet books=stmt.execute();Date:2 August 2022基于WEB的JAVA开发设计52可滚动的结果集可滚动的结果集可滚动结果集是允许你在结果集中的不同行之间进行任意浏可滚动结果集是允许你在结果集中的不同行之间进行任意浏览的览的ResultSet对象。对象。具体的操纵方式包括:具体的操纵方式包括:使
48、用使用next()和和previous()分别向后和向前跳一行分别向后和向前跳一行使用使用first()或或last()方法直接跳到结果集中的第一行或最后方法直接跳到结果集中的第一行或最后一行。一行。使用使用absolute(int)方法直接跳到结果集中指定的行方法直接跳到结果集中指定的行使用使用relative(int)方法向前或向后跳转指定的行数方法向前或向后跳转指定的行数Date:2 August 2022基于WEB的JAVA开发设计53可滚动的结果集可滚动的结果集此外,你还可以使用其他方法:此外,你还可以使用其他方法:beforeFirst(),afterLast():将游标置于第一行
49、之前或最后将游标置于第一行之前或最后一行之后。一行之后。isFirst(),isLast(),isBeforeFirst(),isAfterLast():告诉你告诉你游标是否指向指定的位置。游标是否指向指定的位置。而而beforeFirst()and afterLast()方法告诉你是否还有更多方法告诉你是否还有更多的数据需要处理。的数据需要处理。Date:2 August 2022基于WEB的JAVA开发设计54示例:示例:Statement stmt=connection.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.C
50、ONCUR_READ_ONLY);ResultSet books=stmt.executeQuery(“SELECT*FROM Books”);if(books.last()/this scrolls from the end backwardsdo/do something with this row while(books.previous()Date:2 August 2022基于WEB的JAVA开发设计55为了使创建的结果集具有可滚动性,在创建为了使创建的结果集具有可滚动性,在创建Statement对象对象时需要使用指定的构建函数,该构建函数需要指定两个参数:时需要使用指定的构建函数,