java通过JDBC访问Oracle的2个异常
来源:互联网 发布:js uint8array用法 编辑:程序博客网 时间:2024/04/29 16:07
1. 连接非常慢, 连接成功后执行select操作出现异常:
Exception in thread "main" java.sql.SQLException: ORA-00600: 内部错误代码,参数: [ttcgcshnd-1], [0], [], [], [], [], [], []
解决: 使用oracle安装目录下的jdbc/lib/classes12.jar后正常.
2. 使用PreparedStatement的setString(i, s)时出现:
可以参考帖子:http://community.csdn.net/Expert/topic/3936/3936672.xml?temp=.2879145
java.sql.SQLException: 数据大小超出此类型的最大值: 3000
后面那个值大小不定, 感觉与s大小有关
表结构
create table test(
name char(32),
addr varchar(3000) //varchar2也一样
)
解决办法: 采用setCharacterStream
import java.sql.*;
import java.io.*;
import java.util.*;
/**
* oracle测试
* @author kingfish
* @version 1.0
*/
public class TestOra {
public static void testORACLE() {
String url = "jdbc:oracle:thin:@localhost:1521:oradb";
String username = "system";
String password = "manager";
Connection conn = null;
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
conn = DriverManager.getConnection(url, username, password);
}
catch (Exception e) {
e.printStackTrace();
return;
}
char[] carray = new char[1000];
Arrays.fill(carray, '我');
String s = new String(carray);
try {
PreparedStatement pst = conn.prepareStatement(
"insert into test(name,addr) values(?,?)");
pst.setString(1, "kingfish");
pst.setCharacterStream(2,
new InputStreamReader(new ByteArrayInputStream(s.
getBytes())), s.length());
//pst.setString(2,s); //用此句则异常
pst.execute();
Statement st = conn.createStatement();
ResultSet r = st.executeQuery("SELECT * from test");
while (r.next()) {
s = r.getString(2);
System.out.println("len=" + s.length());
System.out.println("value=" + s);
}
r.close();
st.close();
conn.close();
}
catch (Exception e) {
e.printStackTrace();
}
}
/**
* 测试
* @param args String[]
*/
public static void main(String[] args) {
testORACLE();
}
}
说明: 引起此问题的原因估计和OraclePreparedStatement中的setString的实现有关.
kingfish
- java通过JDBC访问Oracle的2个异常
- java通过JDBC访问Oracle的2个异常
- java通过JDBC访问Oracle的String异常
- oracle jdbc 访问异常
- java通过jdbc对数据库的访问
- Android通过oracle的jdbc驱动直接访问oracle数据库
- 在Java程序中,通过JDBC访问Oracle数据库的步骤
- java通过jdbc访问oracle数据库的存储过程和存储函数
- 如何解决 JMeter 通过 JDBC 访问 Oracle 的问题
- 通过JDBC访问oracle数据库的CLOB类型
- java通过jdbc访问sqlserver2000
- JAVA中通过JDBC访问MS SQLServer2000的常见问题
- JAVA中通过JDBC访问MS SQLServer2000的常见问题
- JAVA中通过JDBC访问MS SQL Server2000的常见问题
- java JDBC访问Oracle数据库
- java JDBC访问Oracle数据库
- java JDBC访问Oracle数据库
- java JDBC访问Oracle数据库
- 数据大小超出此类型的最大值
- jquery.cookie中的操作
- linux环境下给BOOST库编译静态库加上-fPIC选项
- 实验室第二周工作报告
- linux 常用(二)常用文件操作命令
- java通过JDBC访问Oracle的2个异常
- Oracle恢复数据 Tips
- 网易游戏笔试回顾
- LeetCode-Permutation
- 关于Myeclipse中svn插件的安装及配置
- Android BroadcastReceiver详解
- ashx中应用HttpContext.Current.Session ,呈现未将对象引用设置到实例上
- 实验室第二周实验报告-戴宏达
- C与C++中string的区别与联系