在了解jdbc之前呢,我们可以先对odbc做一个回顾,以便于更好的理解jdbc。看名字也知道这两个关系不一般,他们实现了同样的功能,为应用程序连接和操作数据库提供支持。所以,我们先从odbc开始。odbcodbc(open database connectivity)是开放数据库互连的简称,是一种使用sql的应用程序接口。它是一系列的规范和对数据库访问的api。那么api+sql就可以执行对数据库的操作。它是不依赖于dbms的,即通过odbc可以以相同的方式连接大部分数据库。它包括了应用程序接口、驱动器管理器、数据库驱动器、数据源。下面我们通过一副图来了解odbc各个部分之间的关系:
jdbc之前说过了jdbc和odbc实际上的功能是一致的,只不过实现不太一样。首先odbc是基于c++语言的,那么与java的面向对象思想不太相符,通信比较困难。因此,jdbc就出项了,即jdbc是基于java语言的数据库访问api接口。然后其他内容就和odbc基本一致了。只要你了解了odbc,那么在概念上基本就理解了jdbc。那么你需要做的就是对新面孔出项的接口再了解一遍就好了,并且这些接口的功能和odbc是一致的,只是说在实现上有细微的差别。下面也看看jdbc的结构图:
连接方式由上面的结构图可以看出来,jdbc提供了多种不同的连接方式。这个做个大概的了解吧,因为这主要是数据库厂商关心的事,我们知道就好了,有些也确实不是很明白。
1、jdbc-odbc连接桥:这种方式是一位odbc为基础的,上面说了java应用程序和odbc之间的通信是有点麻烦的。但是odbc作为一种数据库访问的标准应用是很广的。因此jdbc通过映射odbc的功能调用就保证了原来使用odbc的数据库也可以很方便的访问的。
2、本地api驱动:即把jdbc调用转换为对数据库接口的客户端二进制代码库的调用。但是这个接口库依赖于产商,因为这里我们调用的不是数据库厂商提供的jdbc的接口实现。
3、纯java本地协议:即把jdbc调用映射为dbms的网络监听协议的功能调用,监听程序监听到请求后执行相关的数据库操作。监听程序是由厂商提供的。
常用接口简介drivermanager关于驱动程序如何注册的,我们不需要知道。我们需要知道的是,如何调用方法去加载得到数据库驱动程序就好了。即class.forname()方法,调用这个方法需要传递一个包含该驱动程序类名的string对象作为实参。如下: class.forname(oracle.jdbc.driver.oracledriver)
connection加载了驱动程序后,与数据库建立连接需要调用drivermanager.getconnection()方法,此方法需要数据库url作为参数,不同的数据库url的有些区别,但都符合“协议名 + ip地址+端口号+数据库名”的格式。数据库用户名和密码如果有,也得加上,如下: string url = jdbc:oracle:thin:@localhost:1521:pdborcl; string username = 123; string password = 123; connection conn = drivermanager.getconnection(url, username, password);
statement执行静态的sql语句,它还可以组合多个sql语句成为一个批处理,整体提交给数据库。我们通过connection对象来创建statement对象,然后用statement的execute方法来执行sql。另外preparedstatement对象是继承自statement对象的,这里我们用preparedstatement为例,需要注意的是批处理只能用statement对象来执行。 preparedstatement pstmt = conn.preparestatement(select * from t_user where userid=?); pstmt.setint(1, id); resultset rs = pstmt.executequery();
resultset执行一个sql查询之后的结果集,result具有指向当前行的指针,可以用来读取结果集中的数据。初始时指针指向第一行前面。该对象的next()方法可以移动指针。如果next()之后的行合法返回true,否则false。因此,循环时next()方法作为判断依据。
到这里jdbc的简单介绍就结束了,jdbc在使用中充当了一个沟通者的角色。这让我想起姚明在nba打球的那个设计模式:适配器模式,这也就成就了java应用程序跨平台的特性。同时,jdbc、odbc等也是面向接口编程思想的典型体现。 对了,这里还缺了一个ole db,没有提及。下回吧……
