我正在尝试使用JDBC在JAVA中连接Microsoft SQL Server 2005但是获得了以下异常。我的项目没有在Eclipse中运行它说“找不到请求的资源”(完成所有服务器配置以及从服务器添加和删除项目),当我从控制台运行它时,它显示我“Class not found exception”我已经把JAR使用构建路径并放入WEB-INF / lib。但是没有得到连接是我的代码。
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import com.microsoft.sqlserver.jdbc.SQLServerDriver;
/**
* @author www.javaworkspace.com
*
*/
public class SMSdao {
public static void main(String[] args) {
try {
Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
Connection connection = DriverManager
.getConnection(
"jdbc:sqlserver://192.128.10.17:1433;databaseName=TEK_R;selectMethod=cursor",
"sa", "sai@123");
System.out.println("DATABASE NAME IS:"
+ connection.getMetaData().getDatabaseProductName());
Statement statement = connection.createStatement();
ResultSet resultSet = statement
.executeQuery("SELECT * FROM dbo.SMS_OUT");
while (resultSet.next()) {
System.out.println("Message:"
+ resultSet.getString("MessageIn"));
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
并且堆栈trcae是:
java.lang.ClassNotFoundException: com.microsoft.sqlserver.jdbc.SQLServerDriver
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:186)
at SMSdao.main(SMSdao.java:13)
尝试一切,做了我在网上发现的所有事情。我在Windows 7上使用jdk 7和tomcat 6.
答案 0 :(得分:2)
您需要从microsoft下载SQLServerDriver JDBC。 Class.forName正在搜索您指定的类名,但在类路径中找不到它。
http://msdn.microsoft.com/en-us/sqlserver/aa937724
将jar放入项目类路径中(tomcat的共享库更好)。
答案 1 :(得分:0)
我还建议改用jTDS:http://jtds.sourceforge.net/
历史上,microsoft的JDBC驱动程序未能完全实现JDBC规范的重要和有用部分。 jTDS应该更加全面,并且是开源的。