java 加载数据库驱动 与forname无关

本文详细解析了JDBC驱动加载机制,通过代码示例解释了如何使用Class.forName()方法加载并实例化数据库驱动,进而实现与数据库的连接。强调了对于纯Java程序而言,通常情况下此步骤可以省略,但在某些环境下如Tomcat中仍需执行。同时,通过案例展示了在特定情况下的错误处理机制。

1.平时加载jdbc的驱动,去连mysql,增删改查,代码如下

String url="jdbc:mysql://localhost/shopping?user=root&password=";   
	//		Object df =  Class.forName("com.mysql.jdbc.Driver");
			Connection conn=DriverManager.getConnection(url);  
			
			Statement stmt = conn.createStatement();
			ResultSet rs = stmt.executeQuery("select * from mytable");
			while(rs.next())
			{
			   System.out.println(rs.getString(1)+"\t"+rs.getString(2)+"<br/>");
			}
			conn.close();
			//DriverManager.getDrivers().toString()
			if(DriverManager.getDrivers().hasMoreElements())
			{
				//Driver drg = (Driver) DriverManager.getDrivers().nextElement();
				DriverManager.deregisterDriver(DriverManager.getDrivers().nextElement());
				//System.out.println(drg.toString());
			}
			DriverManager.deregisterDriver(DriverManager.getDrivers().nextElement());
			
			//DriverManager.deregisterDriver("com.mysql.jdbc.Driver");
		}catch(Exception ex)
		{
			System.out.println("111111"+ex.getMessage());//ex.printStackTrace();
		}
  发现注销掉forname那句话,也能正常获取数据库内容

解释一下,那句话意思是加载类,此处用了forname第三个参数,也就是实例化了这个driver,如果不加这句话,等于这个类没加载,那么下一句

DriverManager.getConnection()怎么去得到连接呢

2.因为jdbc 4.0规定,mysql驱动包mysql***.jar/里的META-INF/services/java.sql.Driver里面已经写了com.mysql.jdbc.Driver,同时当执行

DriverManager.getConnection这句话时,会去前者里读取信息,所以这句forname加载类是多余的。(<span style="color:#ff0000;">对纯java程序,</span><pre name="code" class="java"><span style="color:#ff0000;">这句forname加载类是多余的</span><span style="font-family: Arial, Helvetica, sans-serif;"><span style="color:#ff0000;">,对tomcat对web应用,必须有这句话。另外,tomcat的包里面自带mysql***.jar,所以不用再导入这个jar包。</span>)</span>

3.如图,改了这个文件中的driver名,去掉forname那句话,则不能正确获取mysql内容鸟。

/库mysql***.jar/META-INF/services/java.sql.Driver改成如下


com.mysql.jdbc.Driver11

com.mysql.fabric.jdbc.FabricMySQLDriver1



note:www.huangyunkun.com/2014/03/23/jdbc-with-class-forname


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值