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

被折叠的 条评论
为什么被折叠?



