这是我的代码,其中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 ;
答案 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解决方案: