日期:2014-05-16  浏览次数:20446 次

db2数据库中CLOB字段不能插入内容

今天写了一个JDBC操纵db2中大文本字段的demo,可是一直出错,希望大家帮帮忙看看哪里出错了!

数据库定义:

?

CREATE TABLE
    USERINFO
    (
        USERID INTEGER NOT NULL GENERATED BY DEFAULT AS IDENTITY,
        USERNAME VARCHAR(20) NOT NULL,
        USERAGE INTEGER,
        USERDSP CLOB(200000),
        PRIMARY KEY (USERID)
    )

?数据库操作类:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.sql.Clob;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;


public class PrepareStatementDemo {
          public void add() {
        String sqlString = "insert into USERINFO(USERNAME,USERAGE,USERDSP) values(?,?,?)";
        BasedJdbc basedJdbc = new BasedJdbc();
        PreparedStatement preparedStatement = basedJdbc.getPreparedStatement(sqlString);
        File file = new File("D:\\config\\a.txt");
        
        InputStream inputStream = null;
        try {
            inputStream = new FileInputStream(file);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }
        try {
            preparedStatement.setString(1, "userClob");
            preparedStatement.setInt(2, 1);
            preparedStatement.setAsciiStream(3, inputStream, (int)file.length());
            preparedStatement.execute();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        basedJdbc.close();
    }
}

?单元测试:

import org.testng.annotations.Test;

public class PerparedStatementTest {
       
    @Test    
    public void addTest(){
        PrepareStatementDemo prepareStatementDemo = new PrepareStatementDemo();
        prepareStatementDemo.add();
    }
    
   
}

?运行后控制台信息:

com.ibm.db2.jcc.am.SqlException: DB2 SQL Error: SQLCODE=-668, SQLSTATE=57016, SQLERRMC=7;ROOT.USERINFO, DRIVER=4.12.55
	at com.ibm.db2.jcc.am.hd.a(hd.java:679)
	at com.ibm.db2.jcc.am.hd.a(hd.java:60)
	at com.ibm.db2.jcc.am.hd.a(hd.java:127)
	at com.ibm.db2.jcc.am.mn.b(mn.java:2290)
	at com.ibm.db2.jcc.am.mn.c(mn.java:2273)
	at com.ibm.db2.jcc.t4.cb.k(cb.java:370)
	at com.ibm.db2.jcc.t4.cb.a(cb.java:62)
	at com.ibm.db2.jcc.t4.q.a(q.java:50)
	at com.ibm.db2.jcc.t4.sb.b(sb.java:220)
	at com.ibm.db2.jcc.am.nn.nc(nn.java:3083)
	at com.ibm.db2.jcc.am.nn.b(nn.java:4037)
	at com.ibm.db2.jcc.am.nn.hc(nn.java:2422)
	at com.ibm.db2.jcc.am.nn.execute(nn.java:2402)
	at com.suning.study.jdbc.PrepareStatementDemo.add(PrepareStatementDemo.java:70)
	at com.suning.study.jdbc.PerparedStatementTest.addTest(PerparedStatementTest.java:31)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:80)
	at org.testng.internal.Invoker.invokeMethod(Invoker.java:702)
	at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:894)
	at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1219)
	at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:127)
	at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111)
	at org.testng.TestRunner.privateRun(TestRunner.java:768)
	at org.testng.TestRunner.run(TestRunner.java:617)
	at org.testng.SuiteRunner.runTest(SuiteRunner.java:334)
	at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:329)
	at org.testng.SuiteRunner.privateRun(SuiteRunner.java:291)
	at org.testng.SuiteRunner.run(SuiteRunner.java:240)
	at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:53)
	at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:87)
	at org.testng.TestNG.runSuitesSequentially(Tes