使用Varray将值插入表中

时间:2015-10-30 08:06:37

标签: java sql oracle jdbc

这是我的代码,其中METHODARGDATATYPE_VARRAY是我表中第5列的varray,第一列自动生成的序列与' t'连接。

    List<String> str= new ArrayList<String>();
    str.add("argdataty1");
    str.add("argdataty2");

上面的部分是用main方法编写的,我将设置bean值

    testCaseIDandDetailsBean.setMethodArgDataType(str); 

并将其传递给我执行添加到db的方法

    public String addTestCaseIDandDetails(TestCaseIDandDetailsBean testCaseIDandDetailsBean)

方法中的代码如下所示

     List<String> str= new ArrayList<String>();
     str=testCaseIDandDetailsBean.getMethodArgDataType();

    String arrayElements[] = new String[30];
      int i1=0;
     for(String itr : str){
        arrayElements[i1]=itr.toString();
        System.out.println(arrayElements[i1]);
        i1++;
     }
    String arrayElements[] = { "Test3", "Test4" };
    ArrayDescriptor desc = ArrayDescriptor.createDescriptor
                                    ("METHODARGDATATYPE_VARRAY", conn);
    ARRAY newArray = new ARRAY(desc, conn, arrayElements);

    String sql="insert into TestCaseIDDetails values (concat('t',TestCaseID_sequence.nextval),?,?,?,?)";
    PreparedStatement ps = conn.prepareStatement (sql);
    ps.setString(1,testCaseIDandDetailsBean.getClass_name()) ;
    ps.setString(2,testCaseIDandDetailsBean.getMethod_name()) ;
    ps.setString(3,testCaseIDandDetailsBean.getMethodReplacement()) ;
      ((OraclePreparedStatement)ps).setARRAY (4, newArray);

    ps.execute ();

我的错误是:

    java.sql.SQLException: Exceeded maximum VARRAY limit 
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:146)
at oracle.jdbc.oracore.OracleTypeCOLLECTION.pickle81(OracleTypeCOLLECTION.java:707)
at oracle.jdbc.oracore.OracleTypeADT.pickle81(OracleTypeADT.java:1980)
at oracle.jdbc.oracore.OracleTypeADT.linearize(OracleTypeADT.java:1364)
at oracle.sql.ArrayDescriptor.toBytes(ArrayDescriptor.java:697)
at oracle.sql.ARRAY.toBytes(ARRAY.java:680)
at oracle.jdbc.driver.OraclePreparedStatement.setArrayCritical(OraclePreparedStatement.java:5958)
at oracle.jdbc.driver.OraclePreparedStatement.setARRAYInternal(OraclePreparedStatement.java:5918)
at oracle.jdbc.driver.OraclePreparedStatement.setARRAY(OraclePreparedStatement.java:5898)
at implementation.TestCaseIDandDetailsDAOImpl.addTestCaseIDandDetails(TestCaseIDandDetailsDAOImpl.java:61)
at implementation.TestCaseIDandDetailsDAOImpl.main(TestCaseIDandDetailsDAOImpl.java:141)

我的数据库表是:

   CREATE or replace TYPE METHODARGDATATYPE_VARRAY AS VARRAY(20) OF varchar2(30);
   create table TestCaseIDDetails(
      testcaseID varchar2(20) primary key,
      classname varchar2(20) not null,
      methodname varchar2(20) not null,
      MethodReplacement char(2) check(MethodReplacement in ('y','n')),
      MethodArgDataType METHODARGDATATYPE_VARRAY);

 Create sequence TestCaseID_sequence minvalue 1 start with 1 increment by 1 ;

1 个答案:

答案 0 :(得分:1)

您在第4列中输入的值太大。根据表格定义,它最多接受2个字符,并且该值必须是&#39; y&#39;或者&#39; n&#39;。 (顺便说一句,这是一个奇怪的定义,因为&#39; y&#39;和&#39; n&#39; n&#39; n&#39; n&#39; n&#39; n&#39; n&#39; n&#39; n&#39;问题是你给它10个字符!

因为testCaseIDandDetailsBean.getMethodReplacement()方法没有返回正确的值。

编辑:对于您编辑过的问题(您应该发布另一个问题并将此答案标记为已接受而不是编辑此答案,但无论如何我都会回答): 您插入的数组大于表定义的限制。该表定义了VARRAY(20),因此问题在于您尝试插入包含20个以上元素的数组。 2解决方案:

  • 增加表定义中的限制
  • 制作一个较小的数组