`
ihuashao
  • 浏览: 4723149 次
  • 性别: 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 程序的常见错误及调试方法

    以下是关于JDBC程序中一些常见错误的说明及其调试方法。 首先,驱动程序不存在是开发者在初学JDBC时经常会遇到的一个问题。错误信息通常为java.lang.ClassNotFoundException,提示缺少驱动类,例如在MySQL数据库中...

    C++常见错误及解决方案,c++报错,C,C++

    本资源“C++常见错误及解决方案”提供了一本详细的指南,旨在帮助C++开发者理解和解决这些问题。以下是其中的一些关键知识点: 1. **语法错误**:C++是一种静态类型语言,对语法要求严格。例如,遗漏分号、括号不...

    clickhouse-jdbc(从0.2.4到0.3.2版本).zip

    Clickhouse-JDBC是连接Java应用程序与Clickhouse数据库的桥梁,它允许通过标准的Java Database Connectivity (JDBC) API来执行SQL查询和管理数据。这个压缩包包含从0.2.4版本到0.3.2版本的所有Clickhouse-JDBC驱动,...

    Cannot load JDBC driver class 'com.microsoft.sqlserver.jdbc.SQLServerDriver'

    当出现这个错误时,意味着程序无法找到指定的SQL Server数据库驱动程序,即`com.microsoft.sqlserver.jdbc.SQLServerDriver`。这个问题可能有以下几个原因: 1. **驱动类未正确导入**:在Java项目中,确保已经添加...

    java常见错误以及可能原因集锦

    理解并解决这些常见错误对于Java开发者来说至关重要,它们可以帮助开发者更好地理解和调试代码,从而提高开发效率和程序的稳定性。在遇到这些错误时,仔细检查错误信息,分析可能的原因,并根据上述解决方案进行修复...

    Microsoft SQL Server 2005 JDBC Driver

    Microsoft SQL Server 2005 JDBC Driver是一款由微软公司开发的Java数据库连接(JDBC)驱动,用于在Java应用程序中连接到SQL Server 2005数据库。JDBC驱动是Java平台上的一个标准接口,它使得Java开发者可以使用Java...

    java通过jdbc连接impala所需jar

    Java通过JDBC连接Impala是将Java应用程序与大数据分析平台Impala进行交互的一种常见方法。在Java编程中,JDBC(Java Database Connectivity)是用于访问数据库的标准API,它允许Java程序与各种数据库进行通信,包括...

    JAVA的JDBC学习遇到的问题1

    在"day20"这个文件中,可能包含了作者在学习JDBC的第20天所遇到的问题及解决方案,如连接问题、SQL执行错误、事务处理不当等。由于没有具体文件内容,只能推测可能涉及的方面。学习JDBC需要动手实践,不断调试和解决...

    JDBC视频教程(15天)

    - **常见错误**: - 连接失败:检查URL、用户名和密码是否正确。 - SQL语法错误:仔细检查SQL语句。 - 驱动程序问题:确认JDBC驱动是否与数据库版本匹配。 - **调试技巧**: - 使用日志框架(如Log4j、SLF4J等...

    jdbc测试数据库是否连接成功

    在进行Java应用程序开发时,经常需要通过JDBC(Java Database Connectivity)来连接并操作SQL Server等数据库系统。本文将详细介绍如何利用JDBC连接SQL Server 2005,并验证连接是否成功,同时探讨使用SA用户和...

    mysqljdbc驱动

    在实际开发中,你可能会遇到一些常见问题,如权限不足、超时、网络故障等,这时需要检查数据库配置、网络连接、用户名和密码是否正确,并根据错误信息进行调试。 总的来说,MySQL JDBC驱动是Java程序员连接和操作...

    JDBC Metadata MySQL and Oracle Recipes

    4. **错误处理与调试技巧**:提供处理JDBC元数据操作中常见错误的策略,以及调试技巧。 5. **高级主题**:可能包括事务管理、并发控制、性能调优等更复杂的数据库管理话题。 6. **实践案例分析**:通过具体的应用...

    servlet+jdbc

    这个文件可能是项目中的测试资源,可能包含测试类、配置文件或者其他辅助文件,用于验证和调试代码的功能。测试对于确保代码正确性和性能至关重要。 综上所述,"servlet+jdbc"项目结合了基础的Java Web技术与...

    JDBC问题解决的方法

    以上就是一些常见的JDBC问题及解决方案。在实际开发中,应结合具体的数据库系统和项目需求,灵活运用这些方法来解决问题。通过阅读"JDBC问题解决的方法.pdf",可以更深入地了解和学习JDBC问题的处理技巧。同时,...

    初学者项目实训Java-MySQL-JDBC-BBS源码

    6. **错误处理与日志记录**:查看源码中的异常处理和日志记录,了解如何调试和优化代码。 通过这个项目,初学者不仅能够提升Java编程技能,还能掌握数据库操作和Web应用开发的基本流程,对整体项目架构有更深入的...

    数据池连接Name jdbc is not bound in this Context解决方案

    在这个问题中,开发者遇到了一个常见的错误:“Name jdbc is not bound in this Context”,这通常意味着在Tomcat的环境中,指定的数据源没有被正确地绑定或配置。 要解决这个问题,首先需要在Tomcat的配置文件中...

    java高级程序设计实验指导书 -实验三-jdbc.doc

    实验要求中提到,学生需要记录调试过程中的问题及解决方案,独立完成实验报告,提交源代码和测试结果。这样的实践有助于巩固理论知识,提升解决问题的能力。 在实验过程中,可能会遇到如下的常见问题: - 数据库...

    jdbc问题解决的方法

    通过熟练掌握JDBC的基本原理和最佳实践,结合有效的调试工具和日志,可以迅速定位和解决问题,保证应用程序的稳定运行。在实际开发中,应不断积累经验,了解不同数据库的特性和限制,从而更好地应对可能出现的JDBC...

    jdbc-jar,数据库连接驱动,三个jar包。包括druid连接池,ojdbc1.6,lombok。

    通过在类上添加特定的注解,如`@Data`、`@Setter`和`@Getter`,Lombok会自动生成这些方法,使代码保持整洁,减少因手动编写这些常见方法而引入的错误。这有助于提高开发效率,尤其在大型项目中,Lombok的作用更为...

Global site tag (gtag.js) - Google Analytics