java连接mysql时加Class.forName("Com.mysql.jdbc.Driver").newInstance();和不加有什么区别?我的代码如下
importjava.sql.*;publicclassSampleIntro{publicstaticvoidmain(String[]args){try{Connec...
import java.sql.*;
public class SampleIntro{
public static void main(String[] args){
try{
Connection conn;
Statement stmt;
ResultSet res;
Class.forName("Com.mysql.jdbc.Driver").newInstance();
conn=DriverManager.getConnection
("jdbc:mysql://localhost:3306/test","root","2");
stmt=conn.createStatement();
res=stmt.executeQuery("select * from pet");
while(res.next()){
String name=res.getString("name");
System.out.println(name);
}
res.close();
}
catch(Exception ex){
System.out.println("Error:"+ex.toString());
}
}
}
运行错误是Error:java.lang.ClassNotFoundException: Com.mysql.jdbc.Driver.删除Class.forName("Com.mysql.jdbc.Driver").newInstance();后运行就可以了,请问Class.forName("Com.mysql.jdbc.Driver").newInstance();是什么意思? 展开
public class SampleIntro{
public static void main(String[] args){
try{
Connection conn;
Statement stmt;
ResultSet res;
Class.forName("Com.mysql.jdbc.Driver").newInstance();
conn=DriverManager.getConnection
("jdbc:mysql://localhost:3306/test","root","2");
stmt=conn.createStatement();
res=stmt.executeQuery("select * from pet");
while(res.next()){
String name=res.getString("name");
System.out.println(name);
}
res.close();
}
catch(Exception ex){
System.out.println("Error:"+ex.toString());
}
}
}
运行错误是Error:java.lang.ClassNotFoundException: Com.mysql.jdbc.Driver.删除Class.forName("Com.mysql.jdbc.Driver").newInstance();后运行就可以了,请问Class.forName("Com.mysql.jdbc.Driver").newInstance();是什么意思? 展开
3个回答
展开全部
注册JDBC的驱动
如果你有看过JDBC的书籍,也许会提到过驱动注册这一过程,但在应用中,你基本上不会用到,而仅仅是class.forname这样一句话
如果你下载一个mysql-conn***.jar,打开com.mysql.jdbc.Driver这个类,你就会看到类似的话
class Driver{
static{
DriverManager.registerDriver(new Driver());//应该没记错
}
}
很显然,它帮你注册了驱动,没杳资料,也许是种JDBC驱动的约定
至于楼上的说的,会自动注册,我是从来没见过
如果你有看过JDBC的书籍,也许会提到过驱动注册这一过程,但在应用中,你基本上不会用到,而仅仅是class.forname这样一句话
如果你下载一个mysql-conn***.jar,打开com.mysql.jdbc.Driver这个类,你就会看到类似的话
class Driver{
static{
DriverManager.registerDriver(new Driver());//应该没记错
}
}
很显然,它帮你注册了驱动,没杳资料,也许是种JDBC驱动的约定
至于楼上的说的,会自动注册,我是从来没见过
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询