这是我的代码,其中 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/