`
lixucheng
  • 浏览: 80308 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

JDBC程序的常见错误及调试

阅读更多

本文是《Java Web开发教程——入门与提高篇(JSP+Servlet)》一书《第9章 JDBC技术》的补充内容。

数据库:MySQL

在编写应用的时候,为了调试程序方便,可以在异常处理代码中把异常信息显示出来,这样可以根据错误提示调试代码。异常处理代码通常可以写成这样:

try{

}catch(Exception e){

System.out.println(e.toString());

}

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

1)驱动程序不存在

提示的错误信息如下:

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

后半部分是您在程序中写的驱动程序的名字。

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

2URL写错

提示的错误信息如下:

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

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

12)执行insert语句的时候,值过长

提示的错误信息如下:

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

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

http://blog.csdn.net/javaeeteacher

分享到:
评论

相关推荐

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

    本文是《Java Web开发教程——入门与提高篇(JSP+Servlet)》一书《第9章 JDBC技术》的补充内容。

    《Java语言程序设计》教案设计.doc

    常见错误 " " "课后作业 "1.认真阅读第一章,并预习第二章。 " " "2.做界面: " "项目名称 "Java语言程序设计 " "任务名称 "任务三:数据类型与运算符 "学时数 "8 " "教学目标 "会使用常用数据类型int, double, ...

    《程序天下:J2EE整合详解与典型案例》光盘源码

    1.4.4 JDBC(Java数据库连接) 1.4.5 JTA/JTS(Java事务) 1.4.6 JNDI(Java命名和目录服务) 1.4.7 JavaMail(Java邮件服务) 1.4.8 RMI(远程方法调用) 1.4.9 JMS(Java消息服务) 1.4.10 JMX(Java分布式管理) ...

    java课程设计学生信息管理系统.docx

    3 3 详细设计 3 3.1 图形用户界面的设计 3 3.2 用数据库建立学生信息表 3 3.3 数据库的连接 3 3.4 模块功能的实现 3 4 调试分析 3 4.1 系统功能测试 3 4.2 系统调试常见错误 3 4.3 实验小结 3 5 用户使用说明 3 6 ...

    MySQL5.1参考手册官方简体中文版

    本手册编译于2006-7-29,目录及索引由官方HTML文档转换并加以修订,如有链接错误请发送邮件至: hemono@gmail.com 。获取最新CHM及PDF版本,请访问:hemon.ecjtu.net 。 张伟,华东交通大学。 摘要 这是MySQL参考...

    MySQL 5.1参考手册 (中文版)

    5.1.5. mysqld_multi:管理多个MySQL服务器的程序 5.2. mysqlmanager:MySQL实例管理器 5.2.1. 用MySQL实例管理器启动MySQL服务器 5.2.2. 连接到MySQL实例管理器并创建用户账户 5.2.3. MySQL实例管理器命令行选项 ...

    MySQL 5.1参考手册

    5.1.5. mysqld_multi:管理多个MySQL服务器的程序 5.2. mysqlmanager:MySQL实例管理器 5.2.1. 用MySQL实例管理器启动MySQL服务器 5.2.2. 连接到MySQL实例管理器并创建用户账户 5.2.3. MySQL实例管理器命令行选项 ...

    mysql官方中文参考手册

    5.1.5. mysqld_multi:管理多个MySQL服务器的程序 5.2. mysqlmanager:MySQL实例管理器 5.2.1. 用MySQL实例管理器启动MySQL服务器 5.2.2. 连接到MySQL实例管理器并创建用户账户 5.2.3. MySQL实例管理器命令行选项 ...

    MYSQL中文手册

    5.1.5. mysqld_multi:管理多个MySQL服务器的程序 5.2. mysqlmanager:MySQL实例管理器 5.2.1. 用MySQL实例管理器启动MySQL服务器 5.2.2. 连接到MySQL实例管理器并创建用户账户 5.2.3. MySQL实例管理器命令行...

    MySQL 5.1参考手册中文版

    5.1.5. mysqld_multi:管理多个MySQL服务器的程序 5.2. mysqlmanager:MySQL实例管理器 5.2.1. 用MySQL实例管理器启动MySQL服务器 5.2.2. 连接到MySQL实例管理器并创建用户账户 5.2.3. MySQL实例管理器命令行选项...

    《MyEclipse 6 Java 开发中文教程》前10章

    2.3 使用Eclipse/MyEclipse来编写,编译并运行Java程序 47 2.4小结 50 第三章 Eclipse 的基础概念,配置和使用 51 3.1界面布局 51 3.1.1菜单 51 3.1.2 工具栏 51 3.1.3 透视图(Perspective)切换器 52 3.1.4 视图...

    MySQL 5.1官方简体中文参考手册

    5.1.5. mysqld_multi:管理多个MySQL服务器的程序 5.2. mysqlmanager:MySQL实例管理器 5.2.1. 用MySQL实例管理器启动MySQL服务器 5.2.2. 连接到MySQL实例管理器并创建用户账户 5.2.3. MySQL实例管理器命令行选项 ...

    mysql5.1中文手册

    mysqld_multi:管理多个MySQL服务器的程序 5.2. mysqlmanager:MySQL实例管理器 5.2.1. 用MySQL实例管理器启动MySQL服务器 5.2.2. 连接到MySQL实例管理器并创建用户账户 5.2.3. MySQL实例管理器命令行...

    基于J2EE框架的个人博客系统项目毕业设计论文(源码和论文)

    我们掌握了数据库及其应用技术、数据库原理、计算机网络技术等课程,对数据库的设计、应用、维护及局域网的组成有了深刻的认识与一定的动手实践能力,考取了信息处理、程序设计、数据库技术等国家IT认证。...

    超级有影响力霸气的Java面试题大全文档

     异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获...

    Java面试宝典2020修订版V1.0.1.doc

    6、简述一下ajax调试代码查找错误的方法? 26 7、简述ajax中Js脚本缓存问题该如何解决? 26 8、同步和异步怎么理解?分别在什么情况下使用。 26 9、java后台如何接收ajax数据? 26 10、为什么要有jquery? 26 11、...

Global site tag (gtag.js) - Google Analytics