您的位置:首页 > 编程语言 > Java开发

Eclipse连接JDBC数据库遇到的问题

2015-08-05 13:00 701 查看
今天学习了使用Eclipse工具使用JDBC连接数据库,首先对Mysql数据库进行了连接并测试了,无问题,可是在连接mssql时遇到了问题,

操作步骤如下:

1)首先使用Database Development工具安装mssql jdbc驱动(一共是3个文件sqljdbc.jar, sqljdbc4.jar, sqljdbc41.jar),先将三文件拷贝至一目录

2)建立新的连接,编辑驱动定义信息,添加对应的jar驱动文件



图一
3)输入SQL服务器地址信息,数据库,访问用户及密码信息,点击“测试连接” 可以进行测试,如果出现成功,则表明可以成功连接数据库



图二
测试通过后,编写代码,写了一个数据库连接类,一个测试连接类用户测试前面的类访问是否成功,代码如下:

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.SQLException;

public class Sql {
private String host;
private String user;
private String pass;
private String database;
private String dbURL;
private final String driverName="com.microsoft.jdbc.sqlserver.SQLServerDriver";
private Connection conn;

public String getHost() {
return host;
}
public void setHost(String host) {
this.host = host;
}
public String getUser() {
return user;
}
public void setUser(String user) {
this.user = user;
}
public String getPass() {
return pass;
}
public void setPass(String pass) {
this.pass = pass;
}
public String getDatabase() {
return database;
}
public void setDatabase(String database) {
this.database = database;
}

public int conn(){
if (this.host.isEmpty() || this.database.isEmpty()) return -1;
this.dbURL = "jdbc:sqlserver://" + this.host + ":1433; DatabaseName=" + this.database;
try {
Class.forName(this.driverName);
this.conn = DriverManager.getConnection(this.dbURL, this.user, this.pass);
} catch (Exception e) {
e.printStackTrace();
}
return 0;
}

}

因为只进行测试,故没有写完整,只用于初步进行测试连接使用。进行程序测试,结果发现错误

错误界面如下:



图三
关于问题的思考,因为提示找不到类,所以本人觉得问题应该出现在引用jar文件的问题上,因为连接mysql无问题,我查看mysql驱动所用jar文件存放路径为 d:\eclipse\plugin目录下,后来发现在jdk目录下的jre\lib\ext目录下也找到了mysql的jar驱动文件,怀疑是jar路径所导致的,将3个文件拷至jdk目录下jre\lib\ext目录后,再次进行程序测试,仍然无法通过,仍旧提示找不到类,最终经过多次的测试,重新删除mssql数据块驱动的3个jar文件,反复多次进行测试,发现连接sql2008使用的是sqljdbc4.jar文件,同时又注意到,驱动类略微有所不同,database
development里面的类名为com.microsoft.sqlserver.jdbc.SQLServerDriver,而按照教材上的类名为com.microsoft.jdbc.sqlserver.SQLServerDriver。是不是问题在这里呢?



图四
最终试着将程序中的引入类改为与eclipse database development中设置的一致,再次进行程序测试,连接成功



图五
返回0代表,已成功的连接导数据库。至此问题成功解决!

最后,针对此问题,分享2点心得:

1)通常情况下Project中的系统library是jdk目录中jre\lib\ext目录下的jar文件列表,如果连接数据库不成功,可以先查看这里有无对应的JDBC的JAR文件驱动,若没有,可以通过把jar文件放入jre\lib\ext目录中,或者通过右键JRE System Library添加额外的JAR文件的方式


图六
2)同时若连接url不正确,可以参考图二的方式来解决!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息