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

今天学习了使用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不正确,可以参考图二的方式来解决!

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值