0

我有一个字符串,它是一个插入语句,我需要替换特殊字符?到列表中的特定元素。查询字符串是

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) {


                        }

如果准备好的语句的执行失败,那么我需要调用一个方法来获取整个集合列表并一次插入一个语句并提交。这该怎么做 ?(或)我的想法是,因为我知道数组的大小,我可以将数组分成一半大小,然后为此准备语句并插入它?哪一个更好更安全?有可能这样做吗?

提前致谢

4

4 回答 4

5

您拥有的查询字符串实际上是如何在JDBC中表示具有动态值的 SQL 语句的示例。PreparedStatement请参阅文档中的以下示例,了解通常如何将?查询字符串中的字符替换为适当的值:

PreparedStatement pstmt = con.prepareStatement("UPDATE EMPLOYEES SET SALARY = ? WHERE ID = ?");
pstmt.setBigDecimal(1, 153833.00)
pstmt.setInt(2, 110592)

您还可以在此处查看 Oracle 的 JDBC 基础教程。

于 2012-10-23T13:03:28.807 回答
2

这样,您将永远无法获得格式正确的查询。因为您要替换基本query字符串并将其分配给 new formattedQuery。这formattedQuery将保留所有?占位符,但循环长度的最后一个。这不会产生您所期望的结果。

您实际上应该使用PreparedStatement在查询中设置值。
请参见下面的示例。

示例

PreparedStatement pst = con.prepareStatement( query );
for ( int j = 0; j < list.size(); j++ ) {
    pst.setString( j + 1, list.get( j ).toString() );
}

pst.execute....

更新帖子的答案

只需稍作更改即可执行相同的代码,以提交列表中的有效记录。
我已经部分更改了您的代码,并包含一些注释以供理解,如下所示。
它应该可以解决您的问题:

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++;
      } // for inner list

      // now a record data is ready
      try {
        ps.execute();

        // no errors? then if you don't want to lose, commit this record.
        // because you are fearing if there would be error in next records to be inserted.
        conn.commit();
      } catch ( Exception specificE ) {
        // handle specific ex here
      } // try, catch

      // clear current record parameters from the prepared statement.
      // this allows to set next record parameters in loop continuation.
      ps.clearParameters();
    } // for outer collection
  } // if query
} catch( Exception e ) {
  // handle general ex here
} finally {
  // close db objects if required
} // try, catch, finally
于 2012-10-23T13:06:31.220 回答
0

如果您想继续使用 String,请尝试:

int index = 0;
String formattedQuery = query;
for (int j = 0; j < list.size(); j++) {
     index = query.indexOf("?",index);
     formattedQuery = formattedQuery.replaceFirst("\\?", list.get(j).toString());                        
}
于 2012-10-23T13:01:40.377 回答
0

您可以使用 Java Formatter类,但是这通常使用 % 作为值的占位符而不是 ? 因为它适用于 printf 格式字符串。

那么你可以这样做,

Formatter formatter = new Formatter()
formatter.format("INSERT INTO table_name(a_column, another_column) values(%s,%s)", value1, value2);
String formattedString = formatter.toString();

但是,是的,尝试使用 PreparedStatement。

此外,spring 类SimpleJdbcTemplate有一个update(String sql, Object... args)方法可以完全满足您的需求。

例如。 jdbc.update(sql, value1, value2)

于 2012-10-23T13:05:46.613 回答