免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1617 | 回复: 0
打印 上一主题 下一主题

Java中通过JDBC访问Oracle的2个异常 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-01-30 11:57 |只看该作者 |倒序浏览
Java中通过JDBC访问Oracle的2个异常

1. 连接非常慢, 连接成功后执行select操作出现异常:
Exceptioninthread"main"java.sql.SQLException:ORA-00600:内部错误代码,参
数:[ttcgcshnd-1],[0],[],[],[],[],[],[]
解决:使用oracle安装目录下的jdbc\lib\classes12.jar后正常.
2.使用PreparedStatement的setString(i,s)时出现:

java.sql.SQLException:数据大小超出此类型的最大值:3000
后面那个值大小不定, 感觉与s大小有关
表结构
createtabletest(
namechar(32),
addr varchar(3000) //varchar2也一样
)
解决办法:采用setCharacterStream
--------------------------------------------------------------------------------importjava.sql.*;
importjava.io.*;
importjava.util.*;
/**
*oracle测试
*@authorkingfish
*@version1.0
*/
publicclassTestOra{
publicstaticvoidtestORACLE(){
Stringurl="jdbcracle:thin:@localhost :1521radb";
Stringusername="system";
Stringpassword="manager";
Connectionconn=null;
try{
Class.forName("oracle.jdbc.driver.OracleDriver";
conn=DriverManager.getConnection(url,username,password);
}
catch(Exceptione){
e.printStackTrace();
return;
}
char[]carray=newchar[1000];
Arrays.fill(carray,′我′);
Strings=newString(carray);
try{
PreparedStatementpst=conn.prepareStatement(
"insertintotest(name,addr)values(?,?)";
pst.setString(1,"kingfish";
pst.setCharacterStream(2,
newInputStreamReader(newByteArrayInputStream(s.
getBytes())),s.length());
//pst.setString(2,s); //用此句则异常
pst.execute();
Statementst=conn.createStatement();
ResultSetr=st.executeQuery("SELECT*fromtest";
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(Exceptione){
e.printStackTrace();
}
}
/**
*测试
*@paramargsString[]
*/
publicstaticvoidmain(String[]args){
testORACLE();
}
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP