MySql与oracle的JDBC测试程序

参考文献

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

测试数据库是否正确连接时j2ee开发首先要做的事情,因为如果数据库连接不正确,后期的错误就无法正确判定。所有得先排除数据库连接错误。

一.连接MySql数据库实例

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class MySqlJDBC {
	public static void main(String args[]) {
		try {
			/*
			 * 方法一: 加载MYSQL JDBC驱动程序
			 */
			// Class.forName("org.gjt.mm.mysql.Driver");
			/*
			 * 方法二: 加载MYSQL JDBC驱动程序
			 */
			 Class.forName("com.mysql.jdbc.Driver");
			/*
			 * 方法三:创建com.mysql.jdbc.Driver实例
			 */
			// com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver();
			/*
			 * 方法四:创建com.mysql.jdbc.Driver实例
			 */
			// new com.mysql.jdbc.Driver();

			System.out.println("Success loading Mysql Driver!");
		} catch (Exception e) {
			System.out.print("Error loading Mysql Driver!");
			e.printStackTrace();
		}
		try {
			Connection connect = DriverManager.getConnection(
					"jdbc:mysql://localhost:3306/test", "root", "123456");
			// 连接URL为 jdbc:mysql//服务器地址/数据库名 // 后面的2个参数分别是登陆用户名和密码
			System.out.println("Success connect Mysql server!");
			Statement stmt = connect.createStatement();
			ResultSet rs = stmt.executeQuery("select * from userinfo");
			while (rs.next()) {
				System.out.println(rs.getString("username"));
			}
		} catch (Exception e) {
			System.out.print("get data error!");
			e.printStackTrace();
		}
	}
}

运行结果如下所示:

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

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

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

但是经过我的测试,即使没有将com.mysql.jdbc.Driver加载到JVM中,程序也能够正常运行,程序如下所示
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class MySqlJDBC {
	public static void main(String args[]) {
		try {
			Connection connect = DriverManager.getConnection(
					"jdbc:mysql://localhost:3306/test", "root", "123456");
			// 连接URL为 jdbc:mysql//服务器地址/数据库名 // 后面的2个参数分别是登陆用户名和密码
			System.out.println("Success connect Mysql server!");
			Statement stmt = connect.createStatement();
			ResultSet rs = stmt.executeQuery("select * from userinfo");
			while (rs.next()) {
				System.out.println(rs.getString("username"));
			}
		} catch (Exception e) {
			System.out.print("get data error!");
			e.printStackTrace();
		}
	}
}
运行结果为:
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也会包类似的错误,这里先列出来以便后面进行比较。

三.连接oracle数据库实例

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import oracle.jdbc.driver.OracleDriver;

public class MyOracleJDBC {
	public static void main(String args[]) {
		try {
			/*
			 * 方法一: 加载Oracle JDBC驱动程序
			 */
			 Class.forName("oracle.jdbc.driver.OracleDriver");

			/*
			 * 方法二:创建oracle.jdbc.driver.OracleDriver实例
			 */
			//oracle.jdbc.driver.OracleDriver driver = new oracle.jdbc.driver.OracleDriver();
			
			/*
			 * 方法三:创建oracle.jdbc.driver.OracleDriver实例
			 */
			//new oracle.jdbc.driver.OracleDriver();

			System.out.println("Success loading Oracle Driver!");
		} catch (Exception e) {
			System.out.print("Error loading Oracle Driver!");
			e.printStackTrace();
		}
		try {
			Connection connect = DriverManager.getConnection(
					"jdbc:oracle:thin:@localhost:1521:ORCL", "test", "test");
			System.out.println("Success connect Oracle server!");
			Statement stmt = connect.createStatement();
			ResultSet rs = stmt.executeQuery("select * from userinfo");
			while (rs.next()) {
				System.out.println(rs.getString("username"));
			}
		} catch (Exception e) {
			System.out.print("get data error!");
			e.printStackTrace();
		}
	}
}
通过上述代码我们发现和连接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。

四.MyOracleJDBC实例解析

上述的三种方法同样都能够加载Driver。如果我们也像前面MySqlJDBC实例那样不加载Driver会出现什么情况呢。假设我们注释掉所有加载Driver的语句,代码如下所示:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import oracle.jdbc.driver.OracleDriver;

public class MyOracleJDBC {
	public static void main(String args[]) {
		try {
			Connection connect = DriverManager.getConnection(
					"jdbc:oracle:thin:@localhost:1521:ORCL", "test", "test");
			System.out.println("Success connect Oracle server!");
			Statement stmt = connect.createStatement();
			ResultSet rs = stmt.executeQuery("select * from userinfo");
			while (rs.next()) {
				System.out.println(rs.getString("username"));
			}
		} catch (Exception e) {
			System.out.print("get data error!");
			e.printStackTrace();
		}
	}
}
再次执行此程序,会出错,提示错误如下:
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");

五.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');

六.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,因此现在这两个驱动没有什么区别。

//org.gjt.mm.mysql.Driver的源代码

import java.sql.SQLException;
/**
* Here for backwards compatibility with MM.MySQL
*
* @author Mark Matthews
*/
public class Driver extends com.mysql.jdbc.Driver {
//~ Constructors
//-----------------------------------------------------------

/**
* Creates a new instance of Driver
*
* @throws SQLException
*             if a database error occurs.
*/
  public Driver() throws SQLException
  {
      super();
  }
}


 

 

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值