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

来源:互联网 发布:建筑优化设计 编辑:程序博客网 时间:2024/05/17 10:38

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


0 0
原创粉丝点击