MySql与oracle的JDBC测试程序

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介:

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,如需转载请自行联系原作者





相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
13天前
|
安全 JavaScript Java
AppSpider Pro 7.5.015 for Windows - Web 应用程序安全测试
AppSpider Pro 7.5.015 for Windows - Web 应用程序安全测试
28 12
AppSpider Pro 7.5.015 for Windows - Web 应用程序安全测试
|
11天前
|
SQL Oracle 关系型数据库
MySQL 和 Oracle 的区别?
本文对比了Oracle和MySQL数据库的多个方面。Oracle适用于大型数据库,支持高并发和大访问量,市场占有率为40%,安装占用空间较大,约3G;而MySQL适合中小型应用,是开源免费的,安装仅需152M。两者在主键生成、字符串处理、SQL语句、事务处理等方面存在差异。Oracle功能更为强大,尤其在企业级应用中表现突出,而MySQL则以简单易用见长。
MySQL 和 Oracle 的区别?
|
2月前
|
监控 Oracle 关系型数据库
Mysql、Oracle审计日志的开启
通过上述步骤,可以在 MySQL 和 Oracle 数据库中启用和配置审计日志。这些日志对于监控数据库操作、提高安全性和满足合规性要求非常重要。确保正确配置审计参数和策略,定期查看和分析审计日志,有助于及时发现并处理潜在的安全问题。
66 11
|
9天前
|
SQL Oracle Java
【YashanDB 知识库】oracle 与 yashanDB 的 jdbc 返回常量列"0.00"的精度和刻度不一致
oracle 数值类型只有 number 类型,float 和 integer 都只是 number 类型的子类。 且 oracle 的类型 number 类型还有未定义状态,此时取精度(precision)和刻度(scale) 都是不准确的,如果是未定义状态,还是通过精度和刻度判断是否能够转换为整型也是不严谨的,
|
3月前
|
算法 Java 测试技术
Benchmark.NET:让 C# 测试程序性能变得既酷又简单
Benchmark.NET是一款专为 .NET 平台设计的性能基准测试框架,它可以帮助你测量代码的执行时间、内存使用情况等性能指标。它就像是你代码的 "健身教练",帮助你找到瓶颈,优化性能,让你的应用跑得更快、更稳!希望这个小教程能让你在追求高性能的路上越走越远,享受编程带来的无限乐趣!
167 13
|
4月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
102 1
|
4月前
|
关系型数据库 MySQL 测试技术
【赵渝强老师】MySQL的基准测试与sysbench
本文介绍了MySQL数据库的基准测试及其重要性,并详细讲解了如何使用sysbench工具进行测试。内容涵盖sysbench的安装、基本使用方法,以及具体测试MySQL数据库的步骤,包括创建测试数据库、准备测试数据、执行测试和清理测试数据。通过这些步骤,可以帮助读者掌握如何有效地评估MySQL数据库的性能。
178 5
|
5月前
|
Java 关系型数据库 MySQL
自动化测试项目实战笔记(一):JDK、Tomcat、MySQL、Jpress环境安装和搭建
这篇文章是关于自动化测试项目实战笔记,涵盖了JDK、Tomcat、MySQL、Jpress环境的安装和搭建过程,以及测试用例和常见问题总结。
111 1
自动化测试项目实战笔记(一):JDK、Tomcat、MySQL、Jpress环境安装和搭建
|
5月前
|
安全 Linux 网络安全
Kali渗透测试:远程控制程序基础
Kali渗透测试:远程控制程序基础
78 0
Kali渗透测试:远程控制程序基础
|
5月前
|
安全 Java Linux
Kali渗透测试:通过Web应用程序实现远程控制
Kali渗透测试:通过Web应用程序实现远程控制
73 0

热门文章

最新文章

推荐镜像

更多