JDBC连接MySQL、Sql Server等数据库异常处理_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2116 | 回复: 0   主题: JDBC连接MySQL、Sql Server等数据库异常处理        下一篇 
曹先丰
注册用户
等级:中士
经验:208
发帖:72
精华:0
注册:2012-1-9
状态:离线
发送短消息息给曹先丰 加好友    发送短消息息给曹先丰 发消息
发表于: IP:您无权察看 2014-12-19 16:49:48 | [全部帖] [楼主帖] 楼主

我们在使用JDBC连接MySQL、Sql Server等数据库,在编写应用的时候,常常会遇到各种各样的错误,在这里一一列出供参考。

我们用try catch 来捕获异常。

try{
      …
}
catch(Exception e){
System.out.println(e.toString());
}


下面是一些常见的错误信息:

(1)驱动程序不存在
提示的错误信息如下:

java.lang.ClassNotFoundException: com.mysql.jdbc.Drive


后半部分是您在程序中写的驱动程序的名字。
解决方法:仔细检查类名是否写错,如果类名没有写错,则是驱动程序所在的压缩包没有引入工程,想办法引入。

(2)URL写错
提示的错误信息如下:

java.sql.SQLException: No suitable driver


解决方法:仔细检查URL的格式是否正确,不同数据库的URL格式不同。

(3)主机IP地址不正确或者网络不通
提示的错误信息如下:

com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception:
** BEGIN NESTED EXCEPTION **
java.net.ConnectException
MESSAGE: Connection timed out: connect
STACKTRACE:
java.net.ConnectException: Connection timed out: connect
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(Unknown Source)
at java.net.PlainSocketImpl.connectToAddress(Unknown Source)
at java.net.PlainSocketImpl.connect(Unknown Source)
at java.net.SocksSocketImpl.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:132)
at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:273)
at com.mysql.jdbc.Connection.createNewIO(Connection.java:1639)
at com.mysql.jdbc.Connection.<init>(Connection.java:393)
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:262)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at test.JDBCTest.oracleTest(JDBCTest.java:25)
at test.JDBCTest.main(JDBCTest.java:12)
** END NESTED EXCEPTION **


解决方法:查看IP地址是否正确,网络是否有问题。

(4)端口错误或者数据库服务器没有启动
提示的错误信息如下:

com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception:
** BEGIN NESTED EXCEPTION **
java.net.ConnectException
MESSAGE: Connection refused: connect
STACKTRACE:
java.net.ConnectException: Connection refused: connect
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(Unknown Source)
at java.net.PlainSocketImpl.connectToAddress(Unknown Source)
at java.net.PlainSocketImpl.connect(Unknown Source)
at java.net.SocksSocketImpl.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.connect(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at java.net.Socket.<init>(Unknown Source)
at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:132)
at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:273)
at com.mysql.jdbc.Connection.createNewIO(Connection.java:1639)
at com.mysql.jdbc.Connection.<init>(Connection.java:393)
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:262)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at test.JDBCTest.oracleTest(JDBCTest.java:25)
at test.JDBCTest.main(JDBCTest.java:12)
** END NESTED EXCEPTION **


解决方法:查看端口是否正确,数据库服务器是否启动。

(5)数据库名字不正确
提示的错误信息如下:

java.sql.SQLException: Unknown database 'test2'


解决方法:查看数据库是否存在。

(6)用户名或者口令不正确
提示的错误信息如下:

java.sql.SQLException: Access denied for user 'roo'@'localhost' (using password: YES)


解决方法:确认用户名和口令是否正确。

(7)表名错误
提示的错误信息如下:

java.sql.SQLException: Table 'test.student1' doesn't exist


解决方法:查看表是否存在,表名是否写错。

(8)列名错误
提示的错误信息如下:

java.sql.SQLException: Unknown column 'sid' in 'field list'


解决方案:仔细查看数据库表中的列名。

(9)处理结果集的时候,要获取的列的序号大于列数,或者小于0
提示的错误信息如下:

java.sql.SQLException: Column Index out of range, 4 > 3.


这个错误产生的背景是:数据库表中只有3列,而在取信息的时候使用了rs.getString(4),尤其是在使用循环处理的时候容易犯这样的错误。

(10)执行insert语句的时候,表中的列数与插入语句中的不相同
提示的错误信息如下:

java.sql.SQLException: Column count doesn't match value count at row 1


该错误产生的背景是:数据库表中有3列,而插入的时候给了4个值,SQL语句如下:

insert into student values('0011323','李旭',22,99)。


(11)执行insert语句的时候,主键重复。
提示的错误信息如下:

java.sql.SQLException: Duplicate entry '0011323' for key 1


该错误产生的背景是:1条SQL语句连续执行了两遍,第二遍就出错了。

(12)执行insert语句的时候,值过长
提示的错误信息如下:

java.sql.SQLException: Data too long for column 'id' at row 1


解决方案,查看数据库中列的长度。

希望对大家有帮助!

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论