关闭

常见异常解释及解决办法

标签: 异常解决JAVA
488人阅读 评论(0) 收藏 举报
分类:

在编写应用的时候,为了调试程序方便,可以在异常处理代码中把异常信息显示出来,这样可以根据错误提示调试代码。异常处理代码通常可以写成这样:
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.jb51.net/article/18421.htm

mysql与tomcat不在一台机器上
(1):mysql默认不支持远程连接的【即非一台机器上的应用无法访问mysql】,如要远程访问mysql需要配置远程访问权限【这个你上网上查一下吧】,等有时间我写个blog整理下。
(2):mysql机器是否有什么设置导致3306端口不能让其他机器访问【如防火墙】。
可以使用telnet访问下3306端口。
(3):mysql应用出现问题,这你在mysql服务器尝试下访问下【这个问题的可能性很少】;
mysql与tomcat在同一台机器上
(1):mysql端口是否正确。
(2):服务器是否采用正确的连接方式
(3):是否和本地软件产生冲突。

 

0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

数据库常见问题及解决办法

下面是我在使用数据库时遇到的问题以及贴一下一些很重要的易混淆的概念:Mysql 的9个动词:数据查询:SELECT (查询出数据,也可用于变量赋值)数据定义(表/视图/查询/存储过程/自定义函数/索引...
  • qq_26816591
  • qq_26816591
  • 2016-07-08 23:15
  • 1998

Java中常见异常处理、文件File类、流的知识点总结

一、常见的异常处理情况   在Java中常见的两种异常处理:捕捉异常(try-catch-finally)和抛出异常(throw-throws) 1.捕捉异常(try/catch/finally)...
  • Industrious_ant
  • Industrious_ant
  • 2016-10-22 14:11
  • 1700

Android 的一些基本概念和OOM异常的处理方法

一些基本的概念 ActivityManagerServices,简称AMS,服务端对象,负责系统中所有的Activity的生命周期 ActivityThread,App的真正入口。当开启App之后,会...
  • u010257931
  • u010257931
  • 2016-07-06 10:35
  • 1346

linux centos7 安装MQTT mosquitto时常见异常及解决办法

【1】编译找不到openssl/ssl.h 【解决方法】——安装openssl sudo yum install openssl-devel 【2】编译过程找不到ares.h sudo yum...
  • daodan988
  • daodan988
  • 2017-05-02 15:05
  • 722

Java常见异常和解决办法

1、java.lang.ArithmeticException 算术运算异常,因为除数为0,所以引发了算数异常 2、Java.lang.StringIndexOutOfBoundsExce...
  • u012630060
  • u012630060
  • 2017-04-27 21:12
  • 597

几个oracle,POI,hibernate常见异常解决办法

POI的Unable to read entire block问题解决办法 在网上看到一些关于这个问题的解决办法,甚至修改POI源代码,但至今没有一个完美的解决方案.我在遇到这个问题时是因为对现有e...
  • zb0567
  • zb0567
  • 2012-08-25 09:40
  • 774

常见的异常产生的原因和解决办法

一、数组越界异常 Java.lang.ArrayIndexOutofBoundsException 产生的原因:访问了不存在的索引 解决的办法:索引0到数组长度-1的范围内取值 二、空指针异常 Jav...
  • qq_36859561
  • qq_36859561
  • 2017-12-13 17:43
  • 37

Java常见的12大异常和解决办法

Java常见的12大异常和解决办法 java.lang.ArithmeticException 算术运算异常,因为除数为0,所以引发了算数异常 java.lang.StringIndexOu...
  • imail2016
  • imail2016
  • 2016-06-02 20:18
  • 260

Java常见异常和解决办法

1、java.lang.ArithmeticException 算术运算异常,因为除数为0,所以引发了算数异常 2、java.lang.StringIndexOutOfBoundsException...
  • qq_17168031
  • qq_17168031
  • 2016-05-17 09:59
  • 248

Eclipse之NDK编译——常见异常的解决办法记录

转自http://www.myexception.cn/eclipse/1842938.html ------------------------------------------------...
  • djvc
  • djvc
  • 2016-03-17 14:13
  • 610
    个人资料
    • 访问:89224次
    • 积分:1298
    • 等级:
    • 排名:千里之外
    • 原创:50篇
    • 转载:38篇
    • 译文:0篇
    • 评论:11条
    最新评论