Oracle数据库常见异常错误提示原因

时间:2021-07-21 21:46:30

1、error:无效的数字

      原因:预编译的SQL语句(PreparedStatement)中,查询语句的WHERE子句中不能使用“?=?”的形式来模糊查询。

      相关知识点详细解释预编译语句中的占位符“?”,通过“pstmt.setString(1,"str1")”等类似的方法为占位符“?”,赋值,这类方法会直接把java中的类型直接替换成数据库中相对应的类型


示例:


String sql="delete from students where sdutend_id in (?)";
PreparedStatement pstmt = conn.preparStatement(sql);
pstmt.setString(1,"2,3,4");
以上代码并不会把SQL语句转为:

delete from students where student_id in(2,3,4)
而是转为了:

delete from students where student_id in("2,3,4")

2、error:索引中丢失IN或OUT参数

     原因:未在PreparedStatement对象执行SQL语句前,为占位符”?“赋值。


3、SQLException:并非所有变量都已绑定

     原因:在创建PreparedStatement对象时已经绑定了SQL语句,但在该发送对象执行时,又再次指定了SQL语句。

     示例:

     

String sql = "select * from employees";
PreparedStatement pstmt = conn.prepareStatement(sql);
//省略部分代码
pstmt.executeQuery(sql);//再次指定SQL语句报异常

4、SQLException:日期图片格式转换前结束

      原因:SQL语句中给定的要转换的内容 与 指定的转换格式不匹配。

      示例:

INSERT INTO students(birthday) VALUES (TO_DATE('2013-11-23 00:00:00','yyyy-MM-dd')) WHERE student_id=22

5、SQLException:不支持的特性

     原因:可能是JDBC驱动不支持


6、java.lang.ClassNotFoundException: com.mysql.jdbc.Drive 后半部分是您在程序中写的驱动程序的名字。 

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


7、java.sql.SQLException: No suitable driver 

     原因:创建连接时URL没写对。DriverManeger.getConnection(String url,String user,String password);


以下为部分转载:

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