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:
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 解决方案,查看数据库中列的长度。