我有一个字符串,它是一个插入语句,我需要替换特殊字符?到列表中的特定元素。查询字符串是
insert into OPRS_VEHICLE(VEHICLE_ID, DEPOT_ID, SERVICE_TYPE_ID, REGISTRATION_KEY,
REGISTRATION_NO, IS_ACTIVE,CREATED_BY, CREATED_DATE,
MODIFIED_BY, MODIFIED_DATE) values(?,?,?,?,?,?,?,?,?,?)
现在我需要更换每个?具有列表中包含值的特定元素的字符。
我试过这个
int index = query.indexOf("?");
for (int j = 0; j < list.size(); j++) {
formattedQuery = query.replace(query.substring(index, index+1),
list.get(j).toString());
}
我需要更换?与列表的相应值。
编辑
try{
conn.setAutoCommit(false);
if(query != null){
ps = conn.prepareStatement(query);
for (int i = 0; i < myCollection.size(); i++) {
List list = (List) myCollection.get(i);
int count = 1;
for (int j = 0; j < list.size(); j++) {
if(list.get(j) instanceof Timestamp) {
ps.setTimestamp(count, (Timestamp) list.get(j));
} else if(list.get(j) instanceof java.lang.Character) {
ps.setString(count, String.valueOf(list.get(j)));
}
else {
ps.setObject(count, list.get(j));
}
count++;
}
try {
ps.execute();
} catch (Exception e) {
}
如果准备好的语句的执行失败,那么我需要调用一个方法来获取整个集合列表并一次插入一个语句并提交。这该怎么做 ?(或)我的想法是,因为我知道数组的大小,我可以将数组分成一半大小,然后为此准备语句并插入它?哪一个更好更安全?有可能这样做吗?
提前致谢