【文档说明】Java程序设计项目教程模块6——Java数据库编程.ppt,共(33)页,690.000 KB,由小橙橙上传
转载请保留链接:https://www.ichengzhen.cn/view-2290.html
以下为本文档部分文字说明:
模块6——Java数据库编程6.1与数据库的连接及数据的基本操作项目42使用JDBC-ODBC桥接实现与数据库的连接及查询数据表中的数据JDBC的基本功能◼JavaDataBaseConnectivity,Java数据库连接◼由一组用Java编程语言编写的类和接口组成,是一种可用于执行SQL语句
的JavaAPI◼在java.sql包中定义6.1与数据库的连接及数据的基本操作JDBCAPI中定义的主要类◼数据库驱动程序管理器类DriverManager⚫在用户程序和数据库系统之间维护着与数据库驱动程序之间的连接⚫实现驱动程序的装载⚫创建与数据库系统连接的Connect
ion类对象6.1与数据库的连接及数据的基本操作DriverManager类的常用方法主要功能voidderegisterDriver(Driverdriver)从DriverManager的列表中删除一个驱动程序ConnectiongetConnection
(Stringurl)建立到给定数据库URL的连接ConnectiongetConnection(Stringurl,Propertiesinfo)建立到给定数据库URL的连接Connectionge
tConnection(Stringurl,Stringuser,Stringpassword)建立到给定数据库URL的连接Driver:每个驱动程序类必须实现的接口6.1与数据库的连接及数据的基本操作DrivergetDriver(Stringurl)查找能理解给定URL的驱动程序
Enumeration<Driver>getDrivers()获取带有当前调用者可以访问的所有当前已加载JDBC驱动程序的EnumerationintgetLoginTimeout()获取驱动程序试图登录到某一数据库时可以等待的最长时间,以秒为单位。voidregiste
rDriver(Driverdriver)向DriverManager注册给定驱动程序voidsetLoginTimeout(intseconds)设置驱动程序试图连接到某一数据库时将等待的最长时间,以秒为单位。6.1与数据库的连接及数据的基本操作类Connection用于管理到指定数据
库的连接方法主要功能voidclearWarning()清除为此Connection对象报告的所有警告SQLWarninggetWarnings()获取此Connection对象上的调用报告的第一个警告voidclo
se()即释放此Connection对象的数据库和JDBC资源booleanisClosed()查询此Connection对象是否已经被关闭voidcommit()使所有上一次提交/回滚后进行的更改成为持久更改,并释放此C
onnection对象当前持有的所有数据库锁。6.1与数据库的连接及数据的基本操作StatementcreateStatement(intresultSetType,intresultSetConcurrency)创建一
个Statement对象,该对象将生成具有给定类型和并发性的ResultSet对象•Statement•用于执行静态SQL语句并返回它所生成结果的对象•resultSetType包括:•TYPE_FORWARD_ONLY1003
指针只能向前移动•TYPE_SCROLL_INSENSITIVE1004指针可滚动但通常不受其他的更改影响•TYPE_SCROLL_SENSITIVE1005指针可滚动并且通常受其他的更改影响•resul
tSetConcurrency包括•CONCUR_READ_ONLY1007不可以更新•CONCUR_UPDATABLE1008可以更新6.1与数据库的连接及数据的基本操作StatementcreateStatemen
t()创建一个Statement对象来将SQL语句发送到数据库StringgetCatalog()获取此Connection对象的当前目录名称voidsetCatalog(Stringcatalog)设置给定目录名称Database
MetaDatagetMetaData()获取一个DatabaseMetaData对象,该对象包含关于此Connection对象所连接的数据库的元数据接口DatabaseMetaData(数据库元数据)关于数据库的整体综合信息元数据:描述数据及其环境的数据
•能提供基于用户的信息•能支持系统对数据的管理和维护6.1与数据库的连接及数据的基本操作booleanisReadOnly()查询此Connection对象是否处于只读模式voidsetReadOnly(booleanreadOnly)
将此连接设置为只读模式CallableStatementprepareCall(Stringsql)创建一个CallableStatement对象来调用数据库存储过程CallableStatement:用于执行SQL存储过程的接口PreparedStatement:表示预编译的SQ
L语句的对象PreparedStatementprepareStatement(Stringsql)创建一个PreparedStatement对象来将参数化的SQL语句发送到数据库voidrollback()取消在当前事务中进行的所有更改,并释放此Connection对象当前持有的
所有数据库锁6.1与数据库的连接及数据的基本操作JDBC访问数据库的两种方式◼利用数据库产品的面向ODBC驱动程序,在JDBC和ODBC之间建立JDBC-ODBC桥,在Java程序中基于JDBC-ODBC桥的方式访问数据库◼基于特定数据库产品的JDBC驱动程序,在Java应用程序中利用JDB
C数据驱动程序直接与数据库连接6.1与数据库的连接及数据的基本操作建立数据库连接◼首先必须通过java.lang.Class类的forName()动态加载驱动程序类,加载驱动器的语句为:Class.forName("sun.jdbc.odbc.J
dbcOdbcDrvier");◼再向DriverManager注册JDBC驱动程序,用DriverManager类中的getConnection()方法建立与数据库的连接。Connectioncon=DriverMa
nager.getConnection(url,"数据库的用户名","密码");⚫url是由三部分组成,是提供识别数据库方式的串:<protocol>:<subprotocol>:<subname>例:如果数据源是MyDataSource,则url可以写成:jdbc:odbc:MyD
ataSource6.1与数据库的连接及数据的基本操作创建数据源的步骤(WindowsXP)◼打开控制面版—>性能和维护—>管理工具—>数据源(ODBC)◼在“用户DSN”中单击添加按钮6.1与数据库的连接及数据的
基本操作创建数据源的步骤(WindowsXP)◼选择SQLServer,点击完成按钮◼在名称栏内写上数据源的名字,如MyDataSource服务如果是用本机的话就直接写上“.”号就可以了,如果是用别的服务器,请单击下拉按钮选择。然后
单击下一步6.1与数据库的连接及数据的基本操作创建数据源的步骤(WindowsXP)◼可以选择使用用户输入登录的ID和密码的SQLServer验证,然后设置登录SQL的用户名和密码,如用户名为sa,密码为空,然后点
下一步◼更改默认的数据库(你处理哪个数据库中的数据,就把对应的数据库更改为默认数据库,如pubs),然后点下一步6.1与数据库的连接及数据的基本操作创建数据源的步骤(WindowsXP)◼直接点完成◼点击测试数据源,测试是否连接成功。至此数据源建立
完毕。点击确定按钮退出此对话框6.1与数据库的连接及数据的基本操作创建和执行JDBC语句◼Statement对象可将简单的查询发送到数据库。⚫创建一个Statement对象⚫将想要执行的SQL语句传递给适当的执行方法⚫执行该Statement对象。如:Stateme
ntstat=con.createStatement();◼对于SELECT语句,使用的方法是executeQuery()◼对于创建、插入或更新表的语句,使用的方法是executeUpdate()。如:st
at.executeUpdate(sql);//sql字符串是一条SQL语句6.1与数据库的连接及数据的基本操作处理结果:JDBC将结果集返回给ResultSet对象ResultSetrs=stat.executeQuery(sql
);//sql字符串是一条SQL语句◼ResultSet结果集对象所包含的常用方法如下:⚫next():对象rs包含了结果集中显示的表,将光标移到下一行。光标初始定位于ResultSet对象第一行的上面第一次调用n
ext()将光标移到第一行,使它成为当前行。接下来调用next()将使光标从上至下每次移动一行。⚫getString()常用于检索CHAR和VARCHARSQL类型的数据也能检索其他基本SQL类型的数据例:如果用它检索numeric类型的数据,getString()将把numeri
c值转换成Java的String对象,这样一来,在数据要作为数字前就必须转换回numeric类型6.1与数据库的连接及数据的基本操作◼getXXX():适当类型的getXXX方法可用于检索列中的数值,这里的XXX指列的数据类型⚫检索VAR
CHARSQL类型数值的方法是getString()⚫检索float类型数值的方法是getFloat()while(rs.next()){//每次调用next(),下一行就成为当前行,直到rs中再也没有可向前移动的行为止Strings=rs.getString(strColum
nName1);floatn=rs.getFloat(strColumnName2);//strColumnName1、strColumnName2都是sql字符串中的列名System.out.println(s+""+n);}⚫JDB
C使用两种方法标识getXXX方法检索数值的列指定列名指定列索引(列的序号),i表示第i列如:Strings=rs.getString(1);floatn=rs.getFloat(2);6.1与数据库的连接及数据的基本操作与数据库连接及数据基本操作的步骤◼创
建数据源◼建立数据库连接Class.forName("sun.jdbc.odbc.JdbcOdbcDrvier");Connectioncon=DriverManager.getConnection(u
rl,“数据库用户名”,“密码");◼创建和执行JDBC语句:Statementstat=con.createStatement();◼执行JDBC语句,得到处理结果ResultSetrs=stat.executeQuery(sql);while(rs.next()){××变量名
=rs.get××(列名或列索引);……}◼关闭连接:con.close6.1与数据库的连接及数据的基本操作【应用扩展】使用预备语句◼Statement对象是可以将简单的查询发送到数据库◼发送带参数的查询语句到数据库,可以使用PreparedStatement对象⚫包含一条预编译过的SQL语
句⚫DBMS不必编译就可直接运行PreparedStatement的SQL语句⚫代替Statement对象一般会缩短执行时间⚫PreparedStatement对象可用于不带参数的SQL语句,但在多数场合是用于带参数的SQL语句。6.1与数据库的连
接及数据的基本操作【应用扩展】•使用预备语句其用法如下:StringstrSql="UPDATECOFFEESSETSALES=?WHERECOF_NAMELIKE?";PreparedStatementstat=con.prepareStateme
nt(strSql);stat.setInt(1,75);//给上面的SQL语句的第一个问号赋值stat.setString(2,"Colombian");//给上面的SQL语句的第二个问号赋值stat.execut
eUpdate();//相当于执行UPDATECOFFEESSETSALES=75WHERECOF_NAMELIKE‘Colombian’可用该对象制作成模板实现一次构造多条带参数的SQL语句,简化编码。6.1与数据库的
连接及数据的基本操作【应用扩展】•executeUpdate方法的返回值•executeQuery返回一个ResultSet对象•executeUpdate返回的是一个整数值,指出了表中已更新的行数。如果executeUpdate的返回值为0表明•执行的语句是一不影响任何行的更新语句•
执行的是一无返回内容的SQL语句,比如DLL语句•SQL与Java的数据类型•SQL数据类型与Java的数据类型不一致•在使用Java类型的应用程序与使用SQL类型的数据库之间,需要某种读写类型转换机制•ResultSet类的“get”系列方法
•Statement及其子类的“set”系列方法都有可能要用到数据转换6.1与数据库的连接及数据的基本操作项目43使用纯JavaJDBC实现与数据库的连接及更新•JDBC-ODBC桥•将JDBC数据转换为ODBC数据源,然后
用ODBC与数据连接,速度比较慢。•纯JavaJDBC驱动程序•用纯Java语言编写独立的JDBC驱动程序直接与数据连接•与数据库进行通信的整个过程均由Java语言实现,而不通过桥接或中间件来存取数据库•缺点:•需要下载相
应的类包•不同数据库的连接代码可能不同6.1与数据库的连接及数据的基本操作项目43使用纯JavaJDBC实现与数据库的连接及更新•JDBC-ODBC桥•将JDBC数据转换为ODBC数据源,然后用ODBC与数据连接,速度比较慢。•纯Ja
vaJDBC驱动程序•用纯Java语言编写独立的JDBC驱动程序直接与数据连接•与数据库进行通信的整个过程均由Java语言实现,而不通过桥接或中间件来存取数据库•缺点:•需要下载相应的类包•不同数据库的
连接代码可能不同使用纯JavaJDBC驱动程序连接数据库◼装载驱动程序⚫在程序中,利用Class.forName()方法加载指定的驱动程序Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");⚫注意:连接
不同的数据库时,加载的驱动程序有所不同。◼建立与数据库的连接⚫首先创建指定数据库的URLjdbc:subProtlcol:subName://hostname:port;DatabaseName=XXX⚫JDBC表示
当前通过Java数据库连接进行数据库访问⚫subProtocal表示某种驱动程序支持的数据库连接机制⚫subName表示在当前连接机制下的具体名称⚫hostname表示主机名。port表示相应的连接端口⚫DatabaseName是要连接的数据库的名称。例如:Stringurl="jdbc:sq
lserver://localhost:1433;DatabaseName=pubs";//pubs为数据库名Stringuser=“sa”;//用户名Stringpassword="";//密码Connectionconn=DriverManager.getConnection(url,user
,password);6.1与数据库的连接及数据的基本操作创建存储过程◼CallableStatement对象为所有的DBMS提供了一种以标准形式调用已储存过程的方法◼创建一个存储过程:createprocedurepublishers_
titlesasselectpub_name,titlefrompublishers,titleswherepublishers.pub_id=titles.pub_idorderbytitle◼将SQL语句放到一个字符串中,然后赋给变
量createProcedure以备后用:StringcreateProcedure=”createprocedurepublishers_titlesasselectpub_name,titlefromp
ublishers,titleswherepublishers.pub_id=titles.pub_idorderbytitle”◼使用Connection对象con来创建Statement对象,用于把创建存储过程的SQL语句发送给数据库:Statementstmt=
con.createStatement();stmt.executeUpdate(createProcedure);◼存储过程publishers_titles将作为一个可调用的数据库对象在数据库中编译并存储,调用时就像调用其他方
法一样6.1与数据库的连接及数据的基本操作从JDBC调用存储过程◼创建一个CallableStatement对象⚫利用一个打开的Connection对象即可完成创建⚫CallableStatement对象包含了存储过程的一个调用;但它不包含存
储过程本身如:CallableStatementcs=con.prepareCall("{callpublishers_titles}");ResultSetrs=cs.executeQuery()◼注意⚫用于执行c
s的方法是executeQuery,因为cs调用的存储过程包含一个查询,执行后产生一个结果集⚫如果存储过程包含一条更新或一条DLL语句:executeUpdate方法⚫如果存储过程包含多条SQL语句,产生了多个结果集:e
xecute方法6.2结果集元数据项目44获取数据表的基本信息结果集元数据(ResultSetMetaData)包含结果集的相关信息如字段名和字段类型。根据结果集的元数据,可以得到一个查询结果集关
于查询表中列的个数、各个列名、类型以及各个列的宽度等ResultSetMetaData的对象可以由ResultSet对象的getMetaData()方法得到。在使用结果集前,需要知道记录的行列数◼此类信息存储
在结果集元数据中◼使用结果集中的成员方法“getMetaData()”,便可得到结果集元数据。ResultSetMetaDatarsmd=results.getMetaData();numCols=rsmd.getColum
nCount();//从结果集元数据中取得列数6.2结果集元数据项目44获取数据表的基本信息ResultSetMetaData主要方法主要功能getColumnCount()返回目前ResultSet对象的列数g
etColumnDisplaySize(intcolumn)返回column指定的列的最大宽度getColumnLabel(intcolumn)返回column指定列的标签getColumnName(intcolumn)返回colu
mn指定列的列名getColumnType(int)返回指定号数的字段类型6.2结果集元数据【应用扩展】数据库元数据(DatabaseMetaData)◼包含数据库的有关信息如表名、表索引、数据库产品名和版本号、数据库支持的操作等等。◼DatabaseMetaDa
ta对象的创建如下:DatabaseMetaDatadma=con.getMetaData();//con是Connection的一个对象6.2结果集元数据【应用扩展】DatabaseMetaData类主要方法主要功能ResultSetgetCa
talogs()获取可在此数据库中使用的类别名称。ResultSetgetColumns(catalog,schema,tableNames,columnNames)返回指定表名的表的所有列名getTables(catalog,schema,tablemask,types[])返回符合条件的表
的描述StringgetURL()获取此DBMS的URLStringgetDriverName()获取此JDBC驱动程序的名称StringgetDriverVersion()获取此JDBC驱动程序的Stri
ng形式的版本号StringgetDatabaseProductName()获取此数据库产品的名称StringgetDatabaseProductVersion()获取此数据库产品的版本号StringgetSQLKeywords()获取此
数据库的还“不”是SQL:2003关键字的所有SQL关键字的逗号分隔列表。booleansupportsANSI92EntryLevelSQL()获取此数据库是否支持ANSI92入门级SQL语法booleansupportsANSI92Ful
lSQL()获取此数据库是否支持受支持的ANSI92完全SQL语法booleansupportsStoredProcedures()获取此数据库是否支持使用存储过程转义语法的存储过程调用参数含义catalog表所在的目录◼对于JDBC-ODBC数据库,可置为NULL◼实际上就是数据库所在文件系
统的绝对路径。schema数据库的数据模式,通常置为NULL。ablemask对要获取的表的描述。如果要取得所有表名。可使用通配符“%”。types[]这是一个字符串数组,描述要获取的表的类型。◼如果它为NULL,将得
到所有的表。◼如果是一个单元素的数组含有字符串“TABLES”,只得到与用户有关的例如:获取数据库中的表名。con=DriverManager.getConnection(url);dma=con.getMetaData();String[]
types=newString[1];types[0]=“TABLES”;results=dma.getTables(null,null,“%”,types);