JDBC 程序的常见错误及调试方法

2016-02-19 11:42 91 1 收藏

下面图老师小编要向大家介绍下JDBC 程序的常见错误及调试方法,看起来复杂实则是简单的,掌握好技巧就OK,喜欢就赶紧收藏起来吧!

【 tulaoshi.com - 编程语言 】

数据库:MySQL

在编写应用的时候,为了调试程序方便,可以在异常处理代码中把异常信息显示出来,这样可以根据错误提示调试代码。异常处理代码通常可以写成这样:
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
解决方案,查看数据库中列的长度。

来源:http://www.tulaoshi.com/n/20160219/1598276.html

延伸阅读
标签: 电脑入门
Excel经常会显一些错误值信息,如#N/A!、#VALUE!、#DIV/O!等等。出现这些错误的原因有很多种,最主要是由于公式不能计算正确结果。例如,在需要数字的公式中使用文本、删除了被公式引用的单元格,或者使用了宽度不足以显示结果的单元格。以下是几种Excel常见的错误及其解决方法。 1.#####! 原因:如果单元格所含的数字、日期或时间比单元格宽...
mm.mysql是个类型4(即纯java),符合jdbc 2规范的mysql jdbc驱动程序。当前版本为2.0 pre 5(beta) 你可以从http://www.worldserver.com/mm.mysql/下载最新的驱动程序 本文只是简单描述一下mm.mysql的安装和使用 安装 1、下载mm.mysql 2、解压到某驱动器,如c: 3、修改classpath,加入mm.mysql的路径,如你原来的classpath可能是: .;c:j...
标签: 生活常识
生活中常见的错误梳头方法   一梳到底。 这是人们最常犯的错误。拿起梳子从发根开始,从上到下一梳到底,不仅容易导致头发打结,还会因此拽掉一些无辜的头发。正确梳头应该是先握住一截头发,梳开散乱的发梢,然后再由头发的中段梳向发尾,最后再从发根开始慢慢梳向发梢。 梳头速度快。 为赶时间草草梳几下了...
欢迎来到C#的奇妙天空,在这里,希望你能获得你想获得的东西,.我们真诚希望能给你带来巨大的帮助,带你进入另外一个广阔的空间。 Come on. Follow me and then U can Win! 同Linux下的Gnu C ++ 工具中的gdb类似,C#提供了一个命令行调试程序"Cordbg.exe",通过这个程序你可以很轻松的调试你的C#应用程序,本文在下面不可能完全给...
标签: 除皱 整形
有哪些常见的错误除皱方法 错误的除皱方法尤其影响极大。那么该如何正确选择除皱方式呢。 激光除皱——妊娠女性不适合 首先是激光除皱,妊娠女性理所当然是不能进行激光除皱的:因为治疗有不同程度的疼痛,理论上不能完全排除对胎儿发育可能存在的潜在的影响。所以为了胎儿的健康,你就不要用这种除皱方法了;...

经验教程

809

收藏

52
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部