平台:SQL Server 2000
Java 1.4
String queryStringForCustomer = "{call MIGRATE_CUSTOMERS_FILE(?,?)}";
String queryStringForCard = "{call MIGRATE_CARDS_FILE(?,?)}";
for(int i=0;i<recordIds.size();i++)
{
if(FileType.equals("1")){
callableStatement = connection.prepareCall(queryStringForCustomer);
callableStatement.setString(1,(String)recordIds.get(i));
callableStatement.setInt(2, 0);
callableStatement.execute();
}else {
callableStatement = connection.prepareCall(queryStringForCard);
callableStatement.setString(1,(String)recordIds.get(i));
callableStatement.setInt(2, 0);
callableStatement.execute();
}
callableStatement.close();
}
在excute()调用的以下代码中,它给出sql异常,并显示消息“'{'附近的语法不正确”。
过程声明的起始代码如下
CREATE PROCEDURE MIGRATE_CUSTOMERS_FILE
@FILE_RECORD_ID VARCHAR(200),
@IS_FILE NUMERIC(2) = 1
请帮我解决这个错误?
如果信息不足以解决问题,请告知。
最佳答案
尝试使用prepareStatement(...)
代替prepareCall(...)
。