MYSQL|ORACLE的数据库链接实例______软件开发-数据库
2016-10-13 17:44
543 查看
参考文献
参考1:http://dustin.iteye.com/blog/44291
测试数据库是否正确连接时j2ee开发首先要做的事情,因为如果数据库连接不正确,后期的错误就无法正确判定。所有得先排除数据库连接错误。
运行结果如下所示:
大家可能都看出个大概来了,我们只需要在调用DriverManager的getConnection方法之前,保证相应的Driver类已经被加载到 jvm中,并且完成了类的初始化工作就行了,而具体是怎样实现这个功能却是没有讲究的。上面四种方法都可以实现这个功能,因此程序可以正常运行。我们通常看到的都是使用方法二来加载Driver类到JVM中。这也是大多数教材中所采用的方法
但是经过我的测试,即使没有将com.mysql.jdbc.Driver加载到JVM中,程序也能够正常运行,程序如下所示
加载的Driver名称不同,oracle加载的Driver是oracle.jdbc.driver.OracleDriver,mysql加载的Driver是com.mysql.jdbc.Driver
连接数据的url不同,oracle连接数据库url是jdbc:oracle:thin:@localhost:1521:ORCL,mysql连接数据库url是jdbc:mysql://localhost:3306/test
注意点:在mysql数据库下创建数据名叫做test,里面创建了一张表叫做userinfo。而在oracle中则是在默认数据库orcl中新建用户test,在test用户下创建表userinfo。
上述的三种方法同样都能够加载Driver。如果我们也像前面MySqlJDBC实例那样不加载Driver会出现什么情况呢。假设我们注释掉所有加载Driver的语句,代码如下所示:
疑问:至今不明白为什么mysql数据库连接可以不需要 Class.forName("com.mysql.jdbc.Driver");
从MysqlJdbc.java中我们看到有两种方式加载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,因此现在这两个驱动没有什么区别。
参考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数据库的代码实例相差不多。不同之处基本有连点,分别是:
加载的Driver名称不同,oracle加载的Driver是oracle.jdbc.driver.OracleDriver,mysql加载的Driver是com.mysql.jdbc.Driver
连接数据的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(); } }
相关文章推荐
- 用Java开发的MySQL,Oracle,PostgreSQL数据库web维护管理软件
- 用Java开发的MySQL,Oracle,PostgreSQL,mongoDB 数据库web管理工具软件
- 毛超帅五.MYSQL______软件开发-数据库【mysql_oracle】
- 在sqlserver下增加MYSQL的链接服务器,实现分布式数据库开发第一步
- JDBC 链接Mysql 数据库详细实例
- 简单的C/S结构软件开发笔记(1)——环境与c#链接数据库
- navicat--数据库管理软件(支持mysql,oracle,sqlserver,sqlite,postgreSQL)
- java jdbc链接Oracle,mysql,sql server2012数据库实例
- 一款用Java开发的MySQL,Oracle,PostgreSQL ,SQL Server, mongoDB数据库web管理维护软件
- oracle,mysql,SqlServer三种数据库的分页查询的实例
- oracle,mysql,SqlServer三种数据库的分页查询的实例
- 关于如何通过SSH隧道通过本地软件(plsql,SQLyog等)远程维护服务器数据库(oracle,mysql等)的小技巧
- 下面创建一个链接数据库的开发实例
- oracle,mysql,SqlServer三种数据库的分页查询的实例
- Oracle新手笔记(1)- Oracle 数据库命名问题及使用Oracle数据库开发的软件的命名问题
- JDBC 连接数据库实例(Oracle\SQLServer\MySQL 驱动下载)
- MySql,SqlServer,Oracle链接数据库工具类
- 【转】在sqlserver下增加MYSQL的链接服务器,实现分布式数据库开发第一步
- 【不全,仅参考】iOS开发数据库操作之SQLite及Mysql操作实例
- 数据库开发 Oracle与mysql间的批量处理接口 SSIS+存储过程实现