欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

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