java - 使用 Varray 将值插入表中

标签 java sql oracle jdbc

这是我的代码,其中 METHODARGDATATYPE_VARRAY 是表中第五列的变量,第一列具有与“t”连接的自动生成的序列。

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

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

    testCaseIDandDetailsBean.setMethodArgDataType(str); 

并将其传递给我的方法,其中执行添加到数据库

    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 ;

最佳答案

您在第 4 列中输入的值太大。根据表定义,它最多接受 2 个字符,并且值必须是“y”或“n”。 (顺便说一句,这是一个奇怪的定义,因为“y”和“n”是单个字符,不需要 2)。问题是你给了它 10 个字符!

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

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

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

关于java - 使用 Varray 将值插入表中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33431265/

相关文章:

python - 错误 : cannot locate an Oracle software installation

java - 针对 Errai 3.1.1.Final 编译 GWT 2.7.0

SQL 子查询返回超过 1 个结果

java - 在 Java 中创建自定义注释以强制大写或小写

sql - 应用程序配置或应用程序选项设置的最佳表格设计?

mysql - 仅适用于某些情况的查询

oracle - 设置 USE_SHARED_SOCKET 以通过防火墙访问 Oracle 数据库

java - Oracle JDBC 驱动程序在选择数据时转义\n 到\\n

java - 如何让 JavaFX HBoxes 将项目移动到下一行?

java - JNI 在 android/java 中解析 jstring 或 char* 而不使用 std