Class.forName("com.microsoft.jdbc.sqlserver.SQLserverDriver");报错请问是怎么回事?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Class.forName("com.microsoft.jdbc.sqlserver.SQLserverDriver");报错请问是怎么回事?相关的知识,希望对你有一定的参考价值。

代码如下:
import java.sql.*;
public class Test
public static void main(String[] args)
PreparedStatement ps=null;
Connection ct=null;
ResultSet rs=null;
try
Class.forName("com.microsoft.jdbc.sqlserver.SQLserverDriver");//报错行
ct=DriverManager.getConnection("jdbc:microsoft:sqlserver://127.0.0.1:1433;dataName=hptb1");
ps=ct.prepareStatement("select * form stu");
rs=ps.executeQuery();
catch (SQLException e)
e.printStackTrace();

finally



运行后错误代码:Exception in thread "main" java.lang.Error: Unresolved compilation problem:
Unhandled exception type ClassNotFoundException
at Test.main(Test.java:11)
三个JAR包已经添加上去了

jar包里没这个类,你的jar包版本不对。不信你可以在这里找找,没有的话去换个jar包

参考技术A com.microsoft.jdbc.sqlserver.SQLserverDriver,也许是你jar包冲突,还有一种可能就是你这个有写错了,你到具体的sqljar包中查看有没有这个类,写正确了应该就没问题 参考技术B 您好,提问者:
1、Jar冲突,我不明白您三个jar都有哪三个,怎么会有三个jar?
2、SQL 2005 跟 2008的连接方式跟jar不同。
3、也许您是放到lib下,并没有添加到运行jar环境内。
参考技术C 云行环境中没把驱动jar包添加进去本回答被提问者采纳 参考技术D 根据SQL的版本不同用的jar包不一样,要是是2000的就用msbase.jar,mssqlserver.jar,msutil.jar;2005和2008用的是sqljdbc.jar或者是sqljdbc4.jar

JDBC学习2:为什么要写Class.forName("XXX")?

Class.forName(String name)

接上一篇JDBC。本来这个内容是放在前面的一篇里面的一起的,后来发现越写越多,想想看就算了,还是单独开一篇文章好了,这样也能写得更加详细点。

上一篇文章的第4点,getConnection()方法里面,我把从.properties里面获取mysqlpackage的地方替换成实际的 value值,那么替换后的应该是Class.forName("com.mysql.jdbc.Driver"),实际上所有的JDBC连接先写的基本 上也都是这一句。另外,哪怕删除这一句,也是可以运行成功的。那为什么还要 Class.forName("com.mysql.jdbc.Driver")呢?OK,分点讲解。

1、为什么要Class.forName("com.mysql.jdbc.Driver")?

JDBC是23种模式中的桥接模式的 典型应用,熟悉桥接模式的基本上稍微看一下源代码就知道为什么了,那桥接模式这里不讲,只讲为什么要这么做。 Class.forName(String className)的作用有两个,第一是CLASSPATH下指定名字的.class文件加载到Java虚 拟机内存中, 第二是初始化这个类。看到这句话,返回值都没有,那写在这里的作用很明显了,就是初始化"com.mysql.jdbc.Drvier"。初始化做了什 么?给静态资源赋值以及执行静态代码块,所以,反编译一下"mysql-connector-java-5.1.20-bin.jar"这个jar包,查 看一下Driver类:

复制代码
public class Driver extends NonRegisteringDriver
  implements java.sql.Driver
{
  public Driver()
    throws SQLException
  {
  }

  static
  {
    try
    {
      DriverManager.registerDriver(new Driver());
    } catch (SQLException E) {
      throw new RuntimeException("Can\'t register driver!");
    }
  }
}
复制代码

看到Class.forName("com.mysql.jdbc.Driver")的作用实际上就是调用DriverManager的 registerDriver方法注册一个mysql的JDBC驱动(Driver)而已,Driver继承 NonRegisteringDriver.java,NonRegisteringDriver.java实现了JDK提供的Driver接口,这个 Driver提供了若干数据库连接的方法,每个不同的数据库连接类都必须实现它,并重写和具体的数据库连接的算法。DriverManager也是JDK 中的类,截一些关键代码:

private static final CopyOnWriteArrayList<DriverInfo> registeredDrivers = new CopyOnWriteArrayList();
复制代码
public static synchronized void registerDriver(Driver paramDriver)
    throws SQLException
  {
    if (paramDriver != null)
      registeredDrivers.addIfAbsent(new DriverInfo(paramDriver));
    else
      throw new NullPointerException();
    println("registerDriver: " + paramDriver);
  }
复制代码

底层利用了一个CopyOnWriteArrayList作为容器(这是一个线程安全的容器,不过每次add的时候都会对底层数组进行一次新的复制,所以在读远多于写的时候建议可以使用这个),放那些注册进去的DriverInfo。最终getConnection(...)的时候就拿registerDrivers里面注册进去的具体的某个数据库的DriverInfo(像MySql的Driver就在DriverInfo里面)去连接具体的数据库。OK,所以总结一下整个流程:

JDK不负责和数据库连接打交道,也没必要,只提供一个具体的接口Driver,告诉所有第三方,要连接数据库,就去实现这个接口,然后通过DriverManager注册一下,到时候连接某个数据库的时候,你已经在我这里注册了,我会调用你注册进来的Driver里面的方法去对指定数据库进行连接的。然后Mysql就实现自己的Driver,Oracle就实现自己的Driver,通过static块注册一下,再然后,就没有然后了。

2、为什么不直接new?

意思是这么写"com.mysql.jdbc.Driver d = new com.mysql.jdbc.Driver();",可以啊,因为在new的时候会自动触发对一个类的初始化。问题是new出来干嘛?com.mysql.jdbc.Driver里面的方法我们会用到吗,并且我们知道怎么用吗?仅仅为了初始化一个类而new一个类实例出来还不如不去new,直接使用Class.forName(String name)初始化就可以了。DriverManager类的getConnection(...)方法的存在本身就是帮助用户调用Driver里面的各种方法连接数据库,JDK都做好了,开发者就没必要自己写了。

3、为什么删除Class.forName("com.mysql.jdbc.Driver")还是可以运行?

1996年1月23日JDK1.0发布,Java语言有了第一个正式版本的运行环境。JDBC是1997年2月19日,在JDK1.1的版本中发布的,从版本就看得出,JDBC属于Java技术的一些最基础的功能点。那在JDK1.5之后,其实已经不需要去显式调用Class.forName("com.mysql.jdbc.Driver")了,DriverManager会自动去加载合适的驱动,但是前提是CLASSPATH下必须有驱动jar包

以上是关于Class.forName("com.microsoft.jdbc.sqlserver.SQLserverDriver");报错请问是怎么回事?的主要内容,如果未能解决你的问题,请参考以下文章

为啥我找不到 Class.forName("com.mysql.jdbc.Driver"); 的异常[复制]

h2 数据库的 ClassNotFound 异常 class.forname("org.h2.Driver")

连接数据库时 Class.forName("oracle.jdbc.driver.OracleDriver") 的实际用途是啥?

Class.forName("com.mysql.jdbc.Driver").newInstance()

Class.forName("com.mysql.jdbc.Driver") 没有在 jar 文件中查找该类

Class.forName(Class) 在特定目录中?