基于WEB的JAVA开发设计课件

上传人:磨石 文档编号:240720241 上传时间:2024-05-02 格式:PPT 页数:61 大小:388.50KB
返回 下载 相关 举报
基于WEB的JAVA开发设计课件_第1页
第1页 / 共61页
基于WEB的JAVA开发设计课件_第2页
第2页 / 共61页
基于WEB的JAVA开发设计课件_第3页
第3页 / 共61页
点击查看更多>>
资源描述
Date:5/2/2024基于WEB的JAVA开发设计1基于基于WEBWEB的的JAVAJAVA开发设计开发设计-JDBC-JDBC数据库访问数据库访问Date:5/2/2024基于WEB的JAVA开发设计2主要内容主要内容JDBC简介简介JDBC驱动程序类型驱动程序类型JDBC基本编程基本编程JDBC高级编程高级编程Date:5/2/2024基于WEB的JAVA开发设计3JDBC简介简介JDBC(Java Database Connectivity)是一组用来)是一组用来按照统一方式访问数据库的按照统一方式访问数据库的API。它向程序员提供了它向程序员提供了独立于数据库的统一接口,可以使开发人员不必考虑独立于数据库的统一接口,可以使开发人员不必考虑所用的特定数据库便可编写应用程序,实现了所用的特定数据库便可编写应用程序,实现了Java与与数据库的互连。数据库的互连。它能够:它能够:提供对数据库的跨平台存取提供对数据库的跨平台存取无需知道数据库具体的位置无需知道数据库具体的位置无需要知道数据库实现的具体细节无需要知道数据库实现的具体细节Date:5/2/2024基于WEB的JAVA开发设计4JDBCJava应用应用1OracleMySQL SQL Server Java应用应用nDate:5/2/2024基于WEB的JAVA开发设计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:5/2/2024基于WEB的JAVA开发设计6TYPE 1TYPE 1驱动程序:驱动程序:是是JDBCODBC桥连接方式桥连接方式通常运行在通常运行在Windows系统上系统上需要在客户机上安装需要在客户机上安装ODBC驱动程序驱动程序Date:5/2/2024基于WEB的JAVA开发设计7TYPE 2TYPE 2驱动程序:驱动程序:需要在客户机上安装所用数据对应的本地驱动(这些驱动通需要在客户机上安装所用数据对应的本地驱动(这些驱动通常是常是C或或C+语言所编写的)。语言所编写的)。该驱动将该驱动将JDBC对数据库的调用转换成数据库本地的对数据库的调用转换成数据库本地的API调用调用Date:5/2/2024基于WEB的JAVA开发设计8TYPE 3Date:5/2/2024基于WEB的JAVA开发设计9TYPE 3网络服务可以采用多种技术来提高系统性能,这些服网络服务可以采用多种技术来提高系统性能,这些服务包括:务包括:负载均衡负载均衡缓存技术缓存技术连接池技术连接池技术容错机制容错机制DBMSDate:5/2/2024基于WEB的JAVA开发设计10TYPE 4TYPE 4是一种纯是一种纯Java的驱动实现,他不需要任何客户的驱动实现,他不需要任何客户端配置。端配置。这也是最为常见的数据库连接方式。这也是最为常见的数据库连接方式。Date:5/2/2024基于WEB的JAVA开发设计11Date:5/2/2024基于WEB的JAVA开发设计12DriverManagerDriverManager类类DriverManager(驱动程序管理器驱动程序管理器)类负责管理类负责管理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)设置要进行数据库登录时驱动程序等待的延迟时间设置要进行数据库登录时驱动程序等待的延迟时间Date:5/2/2024基于WEB的JAVA开发设计13ConnectionConnection接口接口Connection对象是通过对象是通过DriverManager.getConnection()方法获得,代表与方法获得,代表与数据库的连接,也就是在已经加载的驱动程序和数据库之间建立连接。数据库的连接,也就是在已经加载的驱动程序和数据库之间建立连接。Connection接口是接口是JSP编程中使用最频繁的接口之一。编程中使用最频繁的接口之一。常用方法如下:常用方法如下:Statement createStatement()throws SQLException创建一个创建一个Statement对象对象PrepareStatement prepareStatement(String sql)throws SQLException创建一个创建一个Preparestatement对象,并能把对象,并能把SQL语句提交到数据库进行预编译语句提交到数据库进行预编译void setAutoCommit(Boolean autocommit)throws SQLException设置事务提交的模式设置事务提交的模式void commit()throws SQLException提交对数据库的更改,使更改生效提交对数据库的更改,使更改生效void rollback()throws SQLException放弃当前事务开始以来对数据库所作的修改放弃当前事务开始以来对数据库所作的修改 Date:5/2/2024基于WEB的JAVA开发设计14StatementStatement接口接口Statement用来执行静态用来执行静态SQL语句。例如,执行语句。例如,执行insert、update、delete语句,可以调用语句,可以调用executeUpdate(String sql)方法,执行方法,执行select语句可以调用语句可以调用executeQuery(String sql)方法,该方法返回方法,该方法返回ResultSet对象。对象。常用方法如下:常用方法如下:ResultSet executeQuery(String sql)throws SQLException执行一个查询语句并返回结果集执行一个查询语句并返回结果集int executeUpdate(String sql)throws SQLException执行更新操作,返回更新的行数执行更新操作,返回更新的行数Boolean execute(String sql)throws SQLException执行更新或查询语句,返回是否有结果集执行更新或查询语句,返回是否有结果集 Date:5/2/2024基于WEB的JAVA开发设计15PreparedStatementPreparedStatement接口接口PreparedStatement接口继承接口继承Statement接口,作为提高性接口,作为提高性能的一条措施,能的一条措施,PreparedStatement提供了可以与查询信息提供了可以与查询信息一起预编译的一种语句类型。一起预编译的一种语句类型。Date:5/2/2024基于WEB的JAVA开发设计16CallableStatementCallableStatement是JDBC用来调用数据库中存储过程的机制具体的使用和PreparedStatement相似需要注意的是:要调用的存储过程必须在数据库中存在,否则将抛出异常Date:5/2/2024基于WEB的JAVA开发设计17ResultSetResultSet接口接口在在Statement执行执行SQL查询语句时,会返回查询语句时,会返回ResultSet查询结果记录集。查询结果记录集。ResultSet接口提供了逐行访问这些记录的方法。接口提供了逐行访问这些记录的方法。常用方法如下:常用方法如下:Boolean next()throws SQLException把当前指针定位到下一行。注意,最初,把当前指针定位到下一行。注意,最初,ResultSet的指针位于第一行的指针位于第一行之前。之前。void close()throws SQLException释放释放ResultSet对象资源对象资源ResultSet提供了提供了getXXX()方法,用于获取当前行中某列的值,其中方法,用于获取当前行中某列的值,其中“XXX”与列的数据类型有关,例如,如要获取的列是与列的数据类型有关,例如,如要获取的列是String类型,则类型,则使用使用getString()方法获取该列的值。方法获取该列的值。getXXX()方法如下所示:方法如下所示:getString()getInt()getFloat()getDouble()getDate()getBoolean()Date:5/2/2024基于WEB的JAVA开发设计18Oracle驱动驱动OracleMYSQLAcessMYSQL驱动驱动JDBCODBC桥桥DriverManagerConnectionPreparedStatementStatementCallableStatementResultSetResultSetResultSet应用层应用层Date:5/2/2024基于WEB的JAVA开发设计19import java.sql.*TryClass.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,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)第一步第一步第二步第二步第三步第三步第四步第四步第五步第五步第六步第六步第七步第七步Date:5/2/2024基于WEB的JAVA开发设计20连接数据库的典型步骤连接数据库的典型步骤第一步:加载正确的数据库驱动程序第一步:加载正确的数据库驱动程序为什么要加载为什么要加载如何加载如何加载Class.forName(oracle.jdbc.driver.OracleDriver);DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver();经过以上其中之一语句的声明后,驱动程序就会自动地加载。经过以上其中之一语句的声明后,驱动程序就会自动地加载。注意:如果注意:如果classpath路径中没有找到所需的驱动程序则会抛出路径中没有找到所需的驱动程序则会抛出 ClassNotFoundException异常。异常。Oracle驱动驱动OracleMYSQLAcessMYSQL驱动驱动JDBCODBC桥桥DriverManagerDate:5/2/2024基于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”;通过此步骤,定义要连接的数据库资源通过此步骤,定义要连接的数据库资源不同数据库连接的地址不同,这点需要特别注意,对弈一些常见的数据库连接不同数据库连接的地址不同,这点需要特别注意,对弈一些常见的数据库连接地址,要求大家能够掌握。地址,要求大家能够掌握。URL由由3部分组成,各个部分用冒号间隔,格式如下:部分组成,各个部分用冒号间隔,格式如下:jdbc:JDBC URL的的3部分可分解如下:部分可分解如下:jdbc:JDBC中的协议就是中的协议就是jdbc。:数据库驱动程序名或数据库连接机制的名称。子协议的典型示:数据库驱动程序名或数据库连接机制的名称。子协议的典型示例为例为oracle,它用于连接,它用于连接oracle数据库。数据库。:一种标记数据库的方法。子名称根据子协议的不同而不同,使:一种标记数据库的方法。子名称根据子协议的不同而不同,使用子名称的目的是为定位数据库用子名称的目的是为定位数据库例如例如 jdbc:oracle:thin:ip:port:sidDate:5/2/2024基于WEB的JAVA开发设计22第三步,建立与数据库的连接第三步,建立与数据库的连接String username=jay_debesee;String password=secret;Connection connection=DriverManager.getConnection(oracleURL,username,password);通过此步获得与数据库服务器的连接通过此步获得与数据库服务器的连接另外,数据库连接还可以使用连接属性信息,如下:另外,数据库连接还可以使用连接属性信息,如下: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.getConnection(jdbc:weblogic:mssqlserver4,dbprops);catch(Exception e).Date:5/2/2024基于WEB的JAVA开发设计23第四步,创建语句对象第四步,创建语句对象Statement statement=connection.createStatement();第五步,声明第五步,声明SQL语句,并将该语句通过语句,并将该语句通过Statement对对象提交给服务器进行执行。象提交给服务器进行执行。Stringsql=“SELECT*FROM ONTACT_TABLE”;ResultSet resultSet=statement.executeQuery(sql);该语句将该语句将sql命令提交给数据库服务器进行执行,并将执行结命令提交给数据库服务器进行执行,并将执行结果存储在果存储在ResultSet对象中进行执行。对象中进行执行。Date:5/2/2024基于WEB的JAVA开发设计24Statement接口主要有如下三个方法:接口主要有如下三个方法:1.ResultSet executeQuery(String sql)用于执行用于执行查询语句,返回,返回 ResultSet结果集(一个二维表)结果集(一个二维表)2.int executeUpdate(String sql)用于执行用于执行添加、删除或修改操作,返回被更新记录的条数操作,返回被更新记录的条数3.boolean execute(String sql)执行参数部分的执行参数部分的SQL语句;语句;当当SQL语句的执行结果是一个语句的执行结果是一个ResultSet结果集时,本方法返回结果集时,本方法返回true;并可以通过;并可以通过StatementgetResultSet()方法得到返回的结方法得到返回的结果集果集 当当SQL语句执行后没有返回的结果集时,该方法返回语句执行后没有返回的结果集时,该方法返回falseDate:5/2/2024基于WEB的JAVA开发设计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)对结果集中的内容进行修改对结果集中的内容进行修改(updateString(col,val),)可以通过可以通过(first(),last(),previous(),next(),absolute(int),)方法浏览可滚动结果集中的内容方法浏览可滚动结果集中的内容支持多个结果集支持多个结果集Date:5/2/2024基于WEB的JAVA开发设计26Java数据类型和数据类型和SQL数据类型之间的映射关系数据类型之间的映射关系SQL类型类型Java数据类型数据类型JDBC访问方法访问方法SQL类型类型Java数据类型数据类型JDBC访问方法访问方法bitbooleangetBoolean()DECIMALjava.math.BigDecimalgetBigDecimal()TINYINTbytegetByte()NUMBERICjava.math.BigDecimalgetBigDecimal()SMALLINTshortgetShort()Charjava.lang.StringgetString()INTEGERintgetInt()VARCHARjava.lang.StringgetString()BIGINTlonggetLong()LONGVARCHARjava.lang.StringgetString()REALfloatgetFloat()DATEjava.sql.dategetDate()FLOATdoublegetDouble()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:5/2/2024基于WEB的JAVA开发设计27第七步,关闭打开的资源第七步,关闭打开的资源resultSet.close();statement.close();connection.close();将打开的资源关闭。将打开的资源关闭。注意:资源关闭的顺序和打开的顺序恰恰相反。注意:资源关闭的顺序和打开的顺序恰恰相反。Date:5/2/2024基于WEB的JAVA开发设计28JDBC-ODBC桥编程实例桥编程实例(Access数据库数据库)创建创建Access数据库数据库student,表,表info,字段,字段id(整型整型),username(文本文本),pass(文本文本),name(文本文本),age(整型整型)具体步骤:具体步骤:建立建立ODBC数据源数据源使用使用JDBC-ODBC驱动建立数据库连接驱动建立数据库连接插入插入/增加两条记录增加两条记录修改一条记录修改一条记录删除一条记录删除一条记录查询所有记录查询所有记录Date:5/2/2024基于WEB的JAVA开发设计29info表结构表结构Date:5/2/2024基于WEB的JAVA开发设计30建立建立ODBC数据源数据源控制面板控制面板管理工具管理工具数据源数据源(ODBC)系统系统DSN添加添加Microsoft Access Driver(*.mdb)数据源名数据源名student,选择刚才所,选择刚才所创建的数据库创建的数据库Date:5/2/2024基于WEB的JAVA开发设计31程序代码程序代码增加增加Date:5/2/2024基于WEB的JAVA开发设计32程序代码程序代码修改修改Date:5/2/2024基于WEB的JAVA开发设计33程序代码程序代码删除删除Date:5/2/2024基于WEB的JAVA开发设计34程序代码程序代码查询查询%Class.forName(sun.jdbc.odbc.JdbcOdbcDriver);Connection con=DriverManager.getConnection(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.print(年龄:年龄:+rs.getFloat(age);out.print();rs.close();stmt.close();con.close();%Date:5/2/2024基于WEB的JAVA开发设计39连接连接MySQL数据库和连接数据库和连接Oracle数据库的方法非常类似。只数据库的方法非常类似。只是有两个地方需要注意一下是有两个地方需要注意一下1).需要把需要把MySQL的驱动程序的驱动程序mysql-connector-java-5.0.4-bin.jar部署到部署到“/WEB-INF/lib/”下。(下。(MySQL驱动程序可以驱动程序可以从其官方网站上下载)从其官方网站上下载)连接连接MySQL数据库数据库Date:5/2/2024基于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,Login,password);密码密码用户名用户名数据库名数据库名IP地址地址端口号端口号连接连接MySQL数据库数据库Date:5/2/2024基于WEB的JAVA开发设计41例:例:MySQL数据库编程实例数据库编程实例Date:5/2/2024基于WEB的JAVA开发设计45高级编程部分高级编程部分在该部分,内容包括:事务的概念使用批处理更新使用PreparedStatement对象使用CallableStatement对象处理可滚动的结果集处理多个结果集处理元数据处理BLOB和CLOB使用事务隔离Date:5/2/2024基于WEB的JAVA开发设计48PreparedStatementPreparedStatement 就是带有占位符的SQL 语句 数据库对他们事先进行编译,因此,客户端需要做的只是传送占位符位置所需要的数据。而普通Statement的SQL语句,只有在程序运行时才对他们进行编译 因此PreparedStatement运行的速度更快。Date:5/2/2024基于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 different second value”);stmt.executeUpdate();Date:5/2/2024基于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 employeeIDs=getIDs();for(int i=0;iemployeeIDs.length;i+)statement.setInt(1,newSalariesi);statement.setInt(2,employeeIDsi);statement.executeUpdate();Date:5/2/2024基于WEB的JAVA开发设计52可滚动的结果集可滚动的结果集可滚动结果集是允许你在结果集中的不同行之间进行任意浏可滚动结果集是允许你在结果集中的不同行之间进行任意浏览的览的ResultSet对象。对象。具体的操纵方式包括:具体的操纵方式包括:使用使用next()和和previous()分别向后和向前跳一行分别向后和向前跳一行使用使用first()或或last()方法直接跳到结果集中的第一行或最后方法直接跳到结果集中的第一行或最后一行。一行。使用使用absolute(int)方法直接跳到结果集中指定的行方法直接跳到结果集中指定的行使用使用relative(int)方法向前或向后跳转指定的行数方法向前或向后跳转指定的行数Date:5/2/2024基于WEB的JAVA开发设计53可滚动的结果集可滚动的结果集此外,你还可以使用其他方法:此外,你还可以使用其他方法:beforeFirst(),afterLast():将游标置于第一行之前或最后将游标置于第一行之前或最后一行之后。一行之后。isFirst(),isLast(),isBeforeFirst(),isAfterLast():告诉你告诉你游标是否指向指定的位置。游标是否指向指定的位置。而而beforeFirst()and afterLast()方法告诉你是否还有更多方法告诉你是否还有更多的数据需要处理。的数据需要处理。Date:5/2/2024基于WEB的JAVA开发设计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 backwardsdo/do something with this row while(books.previous()Date:5/2/2024基于WEB的JAVA开发设计55为了使创建的结果集具有可滚动性,在创建为了使创建的结果集具有可滚动性,在创建Statement对象时对象时需要使用指定的构建函数,该构建函数需要指定两个参数:需要使用指定的构建函数,该构建函数需要指定两个参数:支持滚动支持滚动ResultSet.TYPE_FORWARD_ONLY(不支持滚动不支持滚动)ResultSet.TYPE_SCROLL_SENSITIVE(支持滚动,支持滚动,当更新时,及时更新结果集中的内容当更新时,及时更新结果集中的内容)ResultSet.TYPE_SCROLL_INSENSITIVE(支持滚动,支持滚动,但当数据更新时,并不在本结果集中体现但当数据更新时,并不在本结果集中体现)支持并发支持并发ResultSet.CONCUR_READ_ONLY(禁用更新禁用更新)ResultSet.CONCUR_UPDATABLE(允许更新允许更新)Date:5/2/2024基于WEB的JAVA开发设计57处理元数据处理元数据元数据可以提供一些关于数据库结果的一些信息:元数据可以提供一些关于数据库结果的一些信息:数据库本身的信息数据库本身的信息DatabaseMetaData dbmd=connection.getMetaData();单表的信息单表的信息ResultSet tableRS=connection.getMetaData().getTables(null,null,”TableName”,null);结果集的信息结果集的信息ResultSetMetaData rsmd=resultSet.getMetaData();Date:5/2/2024基于WEB的JAVA开发设计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 tablename=aTable.getString(“TABLE_NAME”);Statement statement=connection.createStatement();ResultSet rs=statement.executeQuery(“SELECT*from”+tablename);ResultSetMetaData rsmd=resultSet.getMetaData();String firstColumn=rsmd.getColumnName(1);System.out.println(“The first column is:”+firstColumn);
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 课件教案


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!