您现在的位置是:首页 > 文章详情

MySql与oracle的JDBC测试程序

日期:2017-12-26点击:505

0.参考文献

参考1:http://dustin.iteye.com/blog/44291

1.前言

测试数据库是否正确连接时j2ee开发首先要做的事情,因为如果数据库连接不正确,后期的错误就无法正确判定。所有得先排除数据库连接错误。下面将详细介绍一下mysql与oracle数据库连接的测试程序

2.mysql数据库连接实例

首先我们给出mysql数据库连接的代码实例,然后再通过这个代码进行详细解析,代码实例如下:

2.1连接MySql数据库实例

View Code

运行结果如下所示:

Success loading Mysql Driver! Success connect Mysql server! zhangsan lisi

2.2MySqlJDBC实例解析(ps:2011-11-17补充)

大家可能都看出个大概来了,我们只需要在调用DriverManager的getConnection方法之前,保证相应的Driver类已经被加载到 jvm中,并且完成了类的初始化工作就行了,而具体是怎样实现这个功能却是没有讲究的。上面四种方法都可以实现这个功能,因此程序可以正常运行。我们通常看到的都是使用方法二来加载Driver类到JVM中。这也是大多数教材中所采用的方法

但是经过我的测试,即使没有将com.mysql.jdbc.Driver加载到JVM中,程序也能够正常运行,程序如下所示:
View Code

运行结果为:

Success connect Mysql server! zhangsan lisi

如果将程序中加载的mysql-connector-java-5.1.18-bin.jar去掉,再次运行程序报错,错误如下所示:

get data error!java.sql.SQLException: No suitable driver found for jdbc:mysql://localhost:3306/test

报错是正常的,后面oracle也会包类似的错误,这里先列出来以便后面进行比较。

3.连接oracle数据库实例

同样,我们首先给出oracle数据库连接的代码实例

3.1连接oralce数据库实例

View Code

通过上述代码我们发现和连接mysql数据库的代码实例相差不多。不同之处基本有连点,分别是:

  1. 加载的Driver名称不同,oracle加载的Driver是oracle.jdbc.driver.OracleDriver,mysql加载的Driver是com.mysql.jdbc.Driver
  2. 连接数据的url不同,oracle连接数据库url是jdbc:oracle:thin:@localhost:1521:ORCL,mysql连接数据库url是jdbc:mysql://localhost:3306/test
注意点:在mysql数据库下创建数据名叫做test,里面创建了一张表叫做userinfo。而在oracle中则是在默认数据库orcl中新建用户test,在test用户下创建表userinfo。

3.2MyOracleJDBC实例解析

上述的三种方法同样都能够加载Driver。如果我们也像前面MySqlJDBC实例那样不加载Driver会出现什么情况呢。假设我们注释掉所有加载Driver的语句,代码如下所示:
View Code

再次执行此程序,会出错,提示错误如下:

java.sql.SQLException: No suitable driver found for jdbc:oracle:thin:@localhost:1521:ORCL at java.sql.DriverManager.getConnection(DriverManager.java:602) at java.sql.DriverManager.getConnection(DriverManager.java:185) at edu.sjtu.erplab.jdbc.MyOracleJDBC.main(MyOracleJDBC.java:33) get data error!

这表示必须得先将oracle.jdbc.driver.OracleDriver加载到JVM中以后才能建立数据库连接。

疑问:至今不明白为什么mysql数据库连接可以不需要  Class.forName("com.mysql.jdbc.Driver");

4.上述测试案例中demo数据库的user表

复制代码
CREATE TABLE `userinfo` ( `userid` int(10) NOT NULL AUTO_INCREMENT, `username` varchar(20) DEFAULT NULL, PRIMARY KEY (`userid`) ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of userinfo -- ---------------------------- INSERT INTO userinfo VALUES ('1', 'zhangsan'); INSERT INTO userinfo VALUES ('2', 'lisi');
复制代码

5.org.gjt.mm.mysql.Driver 和com.mysql.jdbc.Driver的区别

从MysqlJdbc.java中我们看到有两种方式加载MySql JDBC驱动程序,分别是

Class.forName("org.gjt.mm.mysql.Driver"); //方法一: 加载MYSQL JDBC驱动程序 Class.forName("com.mysql.jdbc.Driver");//方法二: 加载MYSQL JDBC驱动程序

这两种方法都能够加载MYSQL JDBC驱动程序,那么到底有何区别呢?其实org.gjt.mm.mysql.Driver是早期的MySQL JDBC驱动程序,但它不是MySQL公司的,后来MySQL将MM的JDBC驱动收为官方的JDBC驱动,并将其改名为com.mysql.jdbc.Driver,在最新版本的mysql jdbc驱动中,为了保持对老版本的兼容,仍然保留了org.gjt.mm.mysql.Driver这个路径的引用,但是实际上org.gjt.mm.mysql.Driver中调用了com.mysql.jdbc.Driver,因此现在这两个驱动没有什么区别。

View Code

 

 

 

 

 

 

 

 


本文转自xwdreamer博客园博客,原文链接:http://www.cnblogs.com/xwdreamer/archive/2010/09/23/2297088.html,如需转载请自行联系原作者





原文链接:https://yq.aliyun.com/articles/352263
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章