Java语言程序设计教程第十二章概述.ppt

Java语言程序设计教程第十二章概述

Java语言程序设计教程;第12章 数据库编程;12.1 JDBC概念;1.JDBC与ODBC ODBC(Open Database Connectivity)指开放式数据库连接,是由Microsoft公司提供的API,包含了连接在任何一种平台,适合任何一种数据库连接的能力,负责连接各种不同产商开发的和不同类型的DBMS,为各种不同的编程语言提供查询、插入、修改和删除数据的功能,即ODBC在各种不同的DBMS和各种不同的编程语言之间架设了一座通用的桥梁。目前使用的Windows各版本的操作系统默认都已安装ODBC驱动程序 简单来说JDBC是ODBC的Java实现。因为ODBC是用C语言实现的API,并不适合在Java中直接使用,Java中调用本地C会消弱Java语言的安全性,健壮性等特点。;2.JDBC驱动程序的类型 使用JDBC连接数据库可以通过不同的驱动方式来实现,根据驱动原理的不同Oracle公司(原Sun Microsystems公司)将JDBC划分为4种类型。 ;1)JDBC-ODBC桥驱动方式 JDBC-ODBC桥利用ODBC驱动程序通过JDBC API访问数据库。这种桥机制实际上是把标准的JDBC调用转换成相应的ODBC调用,并通过ODBC驱动连接数据库的。在JDK中提供了这种桥的实现类(sun.jdbc.odbc.JdbcOdbcDriver类) 2)本地协议的纯Java驱动方式 这种类型的驱动程序完全采用Java编写,采用数据库厂商的协议把客户机API上的JDBC调用转换为Oracle、Sybase、Informix、DB2或其它DBMS的调用。;3)本地API部分Java驱动方式 这种类型的驱动程序使用Java编写,JDBC驱动程序将调用转换为厂商提供的本地API调用,数据库处理完将结果通过API返回给JDBC驱动程序,该驱动程序将结果转化再返回给客户程序。 4)JDBC网络纯Java驱动方式 这种驱动程序将JDBC转换为与DBMS无关的网络协议,之后这种协议又被某个服务器转换为一种DBMS协议。这种网络服务器中间件能够将它的纯Java客户机连接到多种不同的数据库上。;12.2 数据库连接步骤;12.2数据库连接步骤一—— 加载驱动程序 ;在ODBC数据源管理器对话框中选择“用户DSN(Data Source Name)”选项卡,单击“添加”按钮,出现如图12.3所示的数据源驱动程序选择框,根据创建得数据库类型可以在选择列表中选择相应的驱动程序,以SQL Server2000为例,则选择“SQL Server”,单击“完成” ;出现如图12.4所示的创建数据源对话框,为创建的数据源起一个名称,“描述”框中可以为数据库添加说明信息,“服务器”中选择数据库所在的主机名,本机默认为(local),“下一步”后出现SQL Server验证登陆,选择默认值 ;再继续“下一步”出现如图12.5所示的更改默认数据库对话框,选择使用的数据库为默认即可,依次按照默认值“下一步”操作一直到出现图12.6的窗口,表示ODBC加载完成。 ;单击“测试数据源”出现12.7所示的结果为数据源添加成功。;2. 纯Java驱动方式 要使用纯Java驱动方式,首先必须获得相应数据库的驱动程序包,根据数据库的类型,登录对应产商的官方网站,一般都可以免费获得,下载后,复制到本地磁盘,并将完整路径设置到classpath环境变量中,如图12.8和12.9所示。例如对于SQL Server 2000下载得驱动包为SQl Server 2000 Driver for JDBC,包括三个Jar文件:msbase.jar,mssqlserver.jar和msutil.jar。而SQL Server 2008版本的驱动为Microsoft SQL Server JDBC Driver 3.0,解压后能查看到对应的驱动包为sqljdbc4.jar和sqljdbc.jar;图12.8 系统属性环境变量;3.加载并注册驱动程序的forName方法 使用Class类的forName方法,将驱动程序类加载到JVM(Java虚拟机)中,Class是java.lang包中的一个类,该类调用静态方法forName( )加载驱动程序。forName( )方法的定义为:static Class forName(String className) throws ClassNotFoundException;1) 对于使用JDBC-ODBC桥的驱动方式 加载的参数className为sun.jdbc.odbc包中的JdbcOdbcDriver,表示建立JDBC-ODBC桥接器,建立桥接器时可能发生异常,因此要捕获。格式如下: try{ Class.f

文档评论(0)

1亿VIP精品文档

相关文档