Java程序设计项目教程模块6——Java数据库编程

PPT
  • 阅读 63 次
  • 下载 0 次
  • 页数 33 页
  • 大小 690.000 KB
  • 2022-11-12 上传
  • 收藏
  • 违规举报
  • © 版权认领
下载文档25.00 元 加入VIP免费下载
此文档由【小橙橙】提供上传,收益归文档提供者,本网站只提供存储服务。若此文档侵犯了您的版权,欢迎进行违规举报版权认领
Java程序设计项目教程模块6——Java数据库编程
可在后台配置第一页与第二页中间广告代码
Java程序设计项目教程模块6——Java数据库编程
可在后台配置第二页与第三页中间广告代码
Java程序设计项目教程模块6——Java数据库编程
可在后台配置第三页与第四页中间广告代码
Java程序设计项目教程模块6——Java数据库编程
Java程序设计项目教程模块6——Java数据库编程
还剩10页未读,继续阅读
【这是免费文档,您可以免费阅读】
/ 33
  • 收藏
  • 违规举报
  • © 版权认领
下载文档25.00 元 加入VIP免费下载
文本内容

【文档说明】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中定义的主要类◼数据库驱动程序管理器类DriverManage

r⚫在用户程序和数据库系统之间维护着与数据库驱动程序之间的连接⚫实现驱动程序的装载⚫创建与数据库系统连接的Connection类对象6.1与数据库的连接及数据的基本操作DriverManager类的常用方法主要功能voidderegisterDrive

r(Driverdriver)从DriverManager的列表中删除一个驱动程序ConnectiongetConnection(Stringurl)建立到给定数据库URL的连接ConnectiongetConnection(S

tringurl,Propertiesinfo)建立到给定数据库URL的连接ConnectiongetConnection(Stringurl,Stringuser,Stringpassword)建立到

给定数据库URL的连接Driver:每个驱动程序类必须实现的接口6.1与数据库的连接及数据的基本操作DrivergetDriver(Stringurl)查找能理解给定URL的驱动程序Enumeration<Driver>getDrivers()获取带有当

前调用者可以访问的所有当前已加载JDBC驱动程序的EnumerationintgetLoginTimeout()获取驱动程序试图登录到某一数据库时可以等待的最长时间,以秒为单位。voidregisterDriver(Driverd

river)向DriverManager注册给定驱动程序voidsetLoginTimeout(intseconds)设置驱动程序试图连接到某一数据库时将等待的最长时间,以秒为单位。6.1与数据库的连接及数据的基本操作类Connection用于管理到

指定数据库的连接方法主要功能voidclearWarning()清除为此Connection对象报告的所有警告SQLWarninggetWarnings()获取此Connection对象上的调用报告的第一个警告voidclose()即释放此Connection对象的数据库和JDBC资源boole

anisClosed()查询此Connection对象是否已经被关闭voidcommit()使所有上一次提交/回滚后进行的更改成为持久更改,并释放此Connection对象当前持有的所有数据库锁。6.1与数据库的连接及数据的基本操作Stateme

ntcreateStatement(intresultSetType,intresultSetConcurrency)创建一个Statement对象,该对象将生成具有给定类型和并发性的ResultSet对象•St

atement•用于执行静态SQL语句并返回它所生成结果的对象•resultSetType包括:•TYPE_FORWARD_ONLY1003指针只能向前移动•TYPE_SCROLL_INSENSITIVE1004指针可滚动但

通常不受其他的更改影响•TYPE_SCROLL_SENSITIVE1005指针可滚动并且通常受其他的更改影响•resultSetConcurrency包括•CONCUR_READ_ONLY1007不可以更新•CONCUR

_UPDATABLE1008可以更新6.1与数据库的连接及数据的基本操作StatementcreateStatement()创建一个Statement对象来将SQL语句发送到数据库StringgetCatalog()获取此Connection对象的当前目录名称void

setCatalog(Stringcatalog)设置给定目录名称DatabaseMetaDatagetMetaData()获取一个DatabaseMetaData对象,该对象包含关于此Connection对象所连接的数据库

的元数据接口DatabaseMetaData(数据库元数据)关于数据库的整体综合信息元数据:描述数据及其环境的数据•能提供基于用户的信息•能支持系统对数据的管理和维护6.1与数据库的连接及数据的基本操作booleanis

ReadOnly()查询此Connection对象是否处于只读模式voidsetReadOnly(booleanreadOnly)将此连接设置为只读模式CallableStatementprepareCall(Stringsql)创建一个CallableS

tatement对象来调用数据库存储过程CallableStatement:用于执行SQL存储过程的接口PreparedStatement:表示预编译的SQL语句的对象PreparedStatementprepareStatement(Stringsql)创

建一个PreparedStatement对象来将参数化的SQL语句发送到数据库voidrollback()取消在当前事务中进行的所有更改,并释放此Connection对象当前持有的所有数据库锁6.1与数据库的连接及数据的基本操作JDBC访问数据库的两种方式◼利用数据库产品的面向O

DBC驱动程序,在JDBC和ODBC之间建立JDBC-ODBC桥,在Java程序中基于JDBC-ODBC桥的方式访问数据库◼基于特定数据库产品的JDBC驱动程序,在Java应用程序中利用JDBC数据驱动程序直接与数据库连接6.1与数据库的连接及数据的基本操作建立数据库连接◼首先必须通过jav

a.lang.Class类的forName()动态加载驱动程序类,加载驱动器的语句为:Class.forName("sun.jdbc.odbc.JdbcOdbcDrvier");◼再向DriverManager注册JDBC驱

动程序,用DriverManager类中的getConnection()方法建立与数据库的连接。Connectioncon=DriverManager.getConnection(url,"数据库的用户名","密码");⚫url是由三部分组成,是提供识别数据库方

式的串:<protocol>:<subprotocol>:<subname>例:如果数据源是MyDataSource,则url可以写成:jdbc:odbc:MyDataSource6.1与数据库的连接及数据的基本操作创建数据源的步骤(Win

dowsXP)◼打开控制面版—>性能和维护—>管理工具—>数据源(ODBC)◼在“用户DSN”中单击添加按钮6.1与数据库的连接及数据的基本操作创建数据源的步骤(WindowsXP)◼选择SQLServer,点击完成按钮◼在名称栏内写上数据源的名字,如MyData

Source服务如果是用本机的话就直接写上“.”号就可以了,如果是用别的服务器,请单击下拉按钮选择。然后单击下一步6.1与数据库的连接及数据的基本操作创建数据源的步骤(WindowsXP)◼可以选择使用用户输入登录的ID和密码

的SQLServer验证,然后设置登录SQL的用户名和密码,如用户名为sa,密码为空,然后点下一步◼更改默认的数据库(你处理哪个数据库中的数据,就把对应的数据库更改为默认数据库,如pubs),然后点下一步6.1与数据库的

连接及数据的基本操作创建数据源的步骤(WindowsXP)◼直接点完成◼点击测试数据源,测试是否连接成功。至此数据源建立完毕。点击确定按钮退出此对话框6.1与数据库的连接及数据的基本操作创建和执行JDBC语句◼Statement对象可将简单的

查询发送到数据库。⚫创建一个Statement对象⚫将想要执行的SQL语句传递给适当的执行方法⚫执行该Statement对象。如:Statementstat=con.createStatement();◼对于SELECT语句,使

用的方法是executeQuery()◼对于创建、插入或更新表的语句,使用的方法是executeUpdate()。如:stat.executeUpdate(sql);//sql字符串是一条SQL语句6.1与数据库的连接及数据的基本操作

处理结果:JDBC将结果集返回给ResultSet对象ResultSetrs=stat.executeQuery(sql);//sql字符串是一条SQL语句◼ResultSet结果集对象所包含的常用方法如下:⚫

next():对象rs包含了结果集中显示的表,将光标移到下一行。光标初始定位于ResultSet对象第一行的上面第一次调用next()将光标移到第一行,使它成为当前行。接下来调用next()将使光标从上至下每次移动一行。⚫getStri

ng()常用于检索CHAR和VARCHARSQL类型的数据也能检索其他基本SQL类型的数据例:如果用它检索numeric类型的数据,getString()将把numeric值转换成Java的String对象,这样一来,在数据要作为数字前就必须转换回n

umeric类型6.1与数据库的连接及数据的基本操作◼getXXX():适当类型的getXXX方法可用于检索列中的数值,这里的XXX指列的数据类型⚫检索VARCHARSQL类型数值的方法是getString()⚫检索float类型数值的方法是

getFloat()while(rs.next()){//每次调用next(),下一行就成为当前行,直到rs中再也没有可向前移动的行为止Strings=rs.getString(strColumnName1);floatn=rs.getFloat(strColumnName2);//strCo

lumnName1、strColumnName2都是sql字符串中的列名System.out.println(s+""+n);}⚫JDBC使用两种方法标识getXXX方法检索数值的列指定列名指定列索引(列的序号),i表示第i列如:Strings=rs.getString(1);floa

tn=rs.getFloat(2);6.1与数据库的连接及数据的基本操作与数据库连接及数据基本操作的步骤◼创建数据源◼建立数据库连接Class.forName("sun.jdbc.odbc.JdbcOdbcDrvier");Connection

con=DriverManager.getConnection(url,“数据库用户名”,“密码");◼创建和执行JDBC语句:Statementstat=con.createStatement();◼执行JDBC语句,得

到处理结果ResultSetrs=stat.executeQuery(sql);while(rs.next()){××变量名=rs.get××(列名或列索引);……}◼关闭连接:con.close6.1与数据库的连接及数据的基

本操作【应用扩展】使用预备语句◼Statement对象是可以将简单的查询发送到数据库◼发送带参数的查询语句到数据库,可以使用PreparedStatement对象⚫包含一条预编译过的SQL语句⚫DBMS不必编译就可直接运行PreparedStatement的SQL语句⚫代替Stat

ement对象一般会缩短执行时间⚫PreparedStatement对象可用于不带参数的SQL语句,但在多数场合是用于带参数的SQL语句。6.1与数据库的连接及数据的基本操作【应用扩展】•使用预备语句其用法如下:StringstrSql="UPDATECOFFE

ESSETSALES=?WHERECOF_NAMELIKE?";PreparedStatementstat=con.prepareStatement(strSql);stat.setInt(1,75);//给上面的SQL语句的第一个问号赋值stat.setString(2,"Colombian")

;//给上面的SQL语句的第二个问号赋值stat.executeUpdate();//相当于执行UPDATECOFFEESSETSALES=75WHERECOF_NAMELIKE‘Colombian’可用该对象制作成模板实现一次构造多条带参数的SQL语句,简化编码。6.1与数据库的连接及

数据的基本操作【应用扩展】•executeUpdate方法的返回值•executeQuery返回一个ResultSet对象•executeUpdate返回的是一个整数值,指出了表中已更新的行数。如果executeUpdate的返回值为0表明•执行的语句是一不影响任何行的更新

语句•执行的是一无返回内容的SQL语句,比如DLL语句•SQL与Java的数据类型•SQL数据类型与Java的数据类型不一致•在使用Java类型的应用程序与使用SQL类型的数据库之间,需要某种读写类型转换机制•ResultSet类的“get”系列方法•State

ment及其子类的“set”系列方法都有可能要用到数据转换6.1与数据库的连接及数据的基本操作项目43使用纯JavaJDBC实现与数据库的连接及更新•JDBC-ODBC桥•将JDBC数据转换为ODBC数据源,然后用ODBC与数据连接,速度比较慢。•纯JavaJDBC

驱动程序•用纯Java语言编写独立的JDBC驱动程序直接与数据连接•与数据库进行通信的整个过程均由Java语言实现,而不通过桥接或中间件来存取数据库•缺点:•需要下载相应的类包•不同数据库的连接代码可能不同6

.1与数据库的连接及数据的基本操作项目43使用纯JavaJDBC实现与数据库的连接及更新•JDBC-ODBC桥•将JDBC数据转换为ODBC数据源,然后用ODBC与数据连接,速度比较慢。•纯JavaJDBC驱动程序•用纯Java语言编写独立的JDBC驱动程序直接与数据连接•与数据库进行通信的整个

过程均由Java语言实现,而不通过桥接或中间件来存取数据库•缺点:•需要下载相应的类包•不同数据库的连接代码可能不同使用纯JavaJDBC驱动程序连接数据库◼装载驱动程序⚫在程序中,利用Class.forName()方法加载指定的驱动程序Class.forNa

me("com.microsoft.jdbc.sqlserver.SQLServerDriver");⚫注意:连接不同的数据库时,加载的驱动程序有所不同。◼建立与数据库的连接⚫首先创建指定数据库的URLjdbc

:subProtlcol:subName://hostname:port;DatabaseName=XXX⚫JDBC表示当前通过Java数据库连接进行数据库访问⚫subProtocal表示某种驱动程序支持的数据库连接机制⚫subNa

me表示在当前连接机制下的具体名称⚫hostname表示主机名。port表示相应的连接端口⚫DatabaseName是要连接的数据库的名称。例如:Stringurl="jdbc:sqlserver://localhost:1433;DatabaseName=pubs";//pubs为数据

库名Stringuser=“sa”;//用户名Stringpassword="";//密码Connectionconn=DriverManager.getConnection(url,user,password);6.1与数据库的连接及数据的基

本操作创建存储过程◼CallableStatement对象为所有的DBMS提供了一种以标准形式调用已储存过程的方法◼创建一个存储过程:createprocedurepublishers_titlesasselectpub_n

ame,titlefrompublishers,titleswherepublishers.pub_id=titles.pub_idorderbytitle◼将SQL语句放到一个字符串中,然后赋给变量createPro

cedure以备后用:StringcreateProcedure=”createprocedurepublishers_titlesasselectpub_name,titlefrompublishers,titleswherepublishers.pub_id=

titles.pub_idorderbytitle”◼使用Connection对象con来创建Statement对象,用于把创建存储过程的SQL语句发送给数据库:Statementstmt=con.createStateme

nt();stmt.executeUpdate(createProcedure);◼存储过程publishers_titles将作为一个可调用的数据库对象在数据库中编译并存储,调用时就像调用其他方法一样6.1与数据库的连接及数据的基本操作从JDBC调用存储过程◼创建一个CallableState

ment对象⚫利用一个打开的Connection对象即可完成创建⚫CallableStatement对象包含了存储过程的一个调用;但它不包含存储过程本身如:CallableStatementcs=con.prepareCall("{callpublis

hers_titles}");ResultSetrs=cs.executeQuery()◼注意⚫用于执行cs的方法是executeQuery,因为cs调用的存储过程包含一个查询,执行后产生一个结果集⚫如果存储过程包含一条更新或一条DLL语句:ex

ecuteUpdate方法⚫如果存储过程包含多条SQL语句,产生了多个结果集:execute方法6.2结果集元数据项目44获取数据表的基本信息结果集元数据(ResultSetMetaData)包含结果集的相关信息如字段名和字段类型。根据结果集的元数据,可以得到一个查询结果集关

于查询表中列的个数、各个列名、类型以及各个列的宽度等ResultSetMetaData的对象可以由ResultSet对象的getMetaData()方法得到。在使用结果集前,需要知道记录的行列数◼此类信息存储在结果集元数据中◼使用结果集中的成员方法“getMeta

Data()”,便可得到结果集元数据。ResultSetMetaDatarsmd=results.getMetaData();numCols=rsmd.getColumnCount();//从结果集元

数据中取得列数6.2结果集元数据项目44获取数据表的基本信息ResultSetMetaData主要方法主要功能getColumnCount()返回目前ResultSet对象的列数getColumnDisplaySize(intcol

umn)返回column指定的列的最大宽度getColumnLabel(intcolumn)返回column指定列的标签getColumnName(intcolumn)返回column指定列的列名getColumnType(int)返回指定号数的字段类型6.2结果集

元数据【应用扩展】数据库元数据(DatabaseMetaData)◼包含数据库的有关信息如表名、表索引、数据库产品名和版本号、数据库支持的操作等等。◼DatabaseMetaData对象的创建如下:DatabaseMetaDatadma=con.getMetaData();//

con是Connection的一个对象6.2结果集元数据【应用扩展】DatabaseMetaData类主要方法主要功能ResultSetgetCatalogs()获取可在此数据库中使用的类别名称。ResultSetg

etColumns(catalog,schema,tableNames,columnNames)返回指定表名的表的所有列名getTables(catalog,schema,tablemask,types[])返回符合条件的

表的描述StringgetURL()获取此DBMS的URLStringgetDriverName()获取此JDBC驱动程序的名称StringgetDriverVersion()获取此JDBC驱动程序的String形式

的版本号StringgetDatabaseProductName()获取此数据库产品的名称StringgetDatabaseProductVersion()获取此数据库产品的版本号StringgetSQLKeywords()获取此数据库的还“不”是SQL:2003关键字的所有SQL关键字的

逗号分隔列表。booleansupportsANSI92EntryLevelSQL()获取此数据库是否支持ANSI92入门级SQL语法booleansupportsANSI92FullSQL()获取此数据库是否支持受支持的ANSI92

完全SQL语法booleansupportsStoredProcedures()获取此数据库是否支持使用存储过程转义语法的存储过程调用参数含义catalog表所在的目录◼对于JDBC-ODBC数据库,可置为NULL◼实际上就是数据库所在文件系统

的绝对路径。schema数据库的数据模式,通常置为NULL。ablemask对要获取的表的描述。如果要取得所有表名。可使用通配符“%”。types[]这是一个字符串数组,描述要获取的表的类型。◼如果它为NUL

L,将得到所有的表。◼如果是一个单元素的数组含有字符串“TABLES”,只得到与用户有关的例如:获取数据库中的表名。con=DriverManager.getConnection(url);dma=con.getMetaData();String[]types=newString[1];t

ypes[0]=“TABLES”;results=dma.getTables(null,null,“%”,types);

小橙橙
小橙橙
文档分享,欢迎浏览!
  • 文档 25747
  • 被下载 7
  • 被收藏 0
相关资源
广告代码123
若发现您的权益受到侵害,请立即联系客服,我们会尽快为您处理。侵权客服QQ:395972555 (支持时间:9:00-21:00) 公众号
Powered by 太赞文库
×
确认删除?