java通过JDBC访问Oracle的String异常
来源:互联网 发布:淘宝兔八哥店厂货 编辑:程序博客网 时间:2024/05/03 09:13
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的实现有关.
- java通过JDBC访问Oracle的String异常
- java通过JDBC访问Oracle的2个异常
- java通过JDBC访问Oracle的2个异常
- 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数据库
- 卧室清洁攻略
- 6.4 ubuntu 7.04 Linux下刻录光盘
- vc中定时器的使用
- 平衡点
- NXTLOG四足动物(Quadruped)建造挑战赛!
- java通过JDBC访问Oracle的String异常
- 彼得·林奇的25条黄金规则
- Java学习从入门到精通
- 紧张
- 每个IT组织都必须具备的4项安全技术
- 四种性格的人不宜投资股票
- C++中extern “C”含义深层探索
- C/C++堆、栈及静态数据区详解
- debian上安装nfs服务器