• 常见异常


    1..org.postgresql.util.PSQLException: No value specified for parameter 1.(1:代表第一个参数,第几个参数就显示几)没有给第一个参数传参
        解决方案:查看添加入的值
     
    2. java.net.ConnectException: Connection timed out: connect  连接超时
        解决方案:查看是不是因为两台机器之间有一台机器已关闭
                查看是否断网,或者有关服务关闭
     
    3.java.lang.ClassNotFoundException: com.mysql.jdbc.Drive    驱动程序不存在 后半部分是您在程序中写的驱动程序的名字。 
        解决方法:仔细检查类名是否写错,如果类名没有写错,则是驱动程序所在的压缩包没有引入工程,想办法引入。 
     
     
    4.java.sql.SQLException: No suitable driver  URL写错  
        解决方法:仔细检查URL的格式是否正确,不同数据库的URL格式不同。 
     
    5.com.mysql.jdbc.CommunicationsException: Communications link failure due to underlying exception: 主机IP地址不正确或者网络不通 
        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地址是否正确,网络是否有问题。 
     
    6.端口错误或者数据库服务器没有启动 
        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) 
     
        解决方法:查看端口是否正确,数据库服务器是否启动。 
     
    7.java.sql.SQLException: Unknown database 'test2'   数据库名字不正确 
        解决方法:查看数据库是否存在。 
     
    8.java.sql.SQLException: Access denied for user 'roo'@'localhost' (using password: YES)  用户名或者口令不正确 
        解决方法:确认用户名和口令是否正确。 
     
    9.java.sql.SQLException: Table 'test.student1' doesn't exist   表名错误 (不存在)
        解决方法:查看表是否存在,表名是否写错。 
     
    10.java.sql.SQLException: Unknown column 'sid' in 'field list' 列名错误 (不存在)
        解决方案:仔细查看数据库表中的列名。 
     
    11.java.sql.SQLException: Column Index out of range, 4 > 3.  处理结果集的时候,要获取的列的序号大于列数,或者小于0 
        解决方案:这个错误产生的背景是:数据库表中只有3列,而在取信息的时候使用了rs.getString(4),尤其是在使用循环处理的时候容易犯这样的错误。 
     
    12.java.sql.SQLException: Column count doesn't match value count at row 1  执行insert语句的时候,表中的列数与插入语句中的不相同 
        该错误产生的背景是:数据库表中有3列,而插入的时候给了4个值,SQL语句如下: 
        insert into student values('0011323','李旭',22,99)。 
     
     
    13.java.sql.SQLException: Duplicate entry '0011323' for key 1    执行insert语句的时候,主键重复。 
         该错误产生的背景是:1条SQL语句连续执行了两遍,第二遍就出错了。 
     
     
    14.java.sql.SQLException: Data too long for column 'id' at row 1 执行insert语句的时候,值过长 
        解决方案,查看数据库中列的长度。 
        详细出处参考:http://www.jb51.net/article/18421.htm
     
    15.mysql与tomcat不在一台机器上 
        (1):mysql默认不支持远程连接的【即非一台机器上的应用无法访问mysql】,如要远程访问mysql需要配置远程访问权限【这个你上网上查一下吧】,等有时间我写个blog整理下。 
        (2):mysql机器是否有什么设置导致3306端口不能让其他机器访问【如防火墙】。 
        可以使用telnet访问下3306端口。 
        (3):mysql应用出现问题,这你在mysql服务器尝试下访问下【这个问题的可能性很少】; 
        mysql与tomcat在同一台机器上 
        (1):mysql端口是否正确。 
        (2):服务器是否采用正确的连接方式 
        (3):是否和本地软件产生冲突。 
     
     
    16.    foreach循环的时候,例:
        for (Document document : listDocument) {.......}
        如果listDocument为Null  也会抛nullexception
    业勤于精荒于嬉 http://www.cnblogs.com/maxlei/
  • 相关阅读:
    前端学习(六):body标签(四)
    前端学习(五):body标签(三)
    前端学习(四):body标签(二)
    前端学习(三):body标签(一)
    volatile的作用以及原理解析
    【转载】synchronized锁的升级过程
    从三个层面解析synchronized原理
    将网页图片转base64打包导出实战和踩坑
    synchronized锁住的到底是什么以及用法作用
    多线程之程序的局部性原理和伪共享问题
  • 原文地址:https://www.cnblogs.com/maxlei/p/5954019.html
Copyright © 2020-2023  润新知