JDBC получить генерируемые ключи вместе с другими данными эффективно - PullRequest
0 голосов
/ 27 октября 2011

После пакетной вставки ряда строк я хочу получить сгенерированные ключи вместе с соответствующими им вставленными строками. как мне сделать это эффективно?
Наивно я могу использовать Statement.getGeneratedKeys () для запроса базы данных для каждой строки на основе каждого сгенерированного идентификатора, но это кажется медленным.
Приведенный ниже код выполняет пакетную вставку и затем просматривает все результаты в таблице, однако я не хочу включать данные, которые уже существуют в таблице до вставки.
есть ли альтернатива?


      public static void main(String[] args) throws Exception {
        Connection conn = getMySqlConnection();
        ResultSet rs = null;
        Statement stmt = null;
        try {
            conn = getMySqlConnection();
            stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
                                        ResultSet.CONCUR_UPDATABLE);
            conn.setAutoCommit(false);
            stmt.addBatch("INSERT INTO survey(id, name) VALUES('11', 'Alex')");
            stmt.addBatch("INSERT INTO survey(id, name) VALUES('22', 'Mary')");
            stmt.addBatch("INSERT INTO survey(id, name) VALUES('33', 'Bob')");
            int[] updateCounts = stmt.executeBatch();
            System.out.println(updateCounts);
            conn.commit();
            rs = stmt.executeQuery("SELECT * FROM survey");
            while (rs.next()) {
                String id = rs.getString("id");
                String name = rs.getString("name");
                System.out.println("id="+id +"  name="+name);
            }
        }
        catch(BatchUpdateException b) {
            System.err.println("SQLException: " + b.getMessage());
            System.err.println("SQLState: " + b.getSQLState());
            System.err.println("Message: " + b.getMessage());
            System.err.println("Vendor error code: " + b.getErrorCode());
            System.err.print("Update counts: ");
            int [] updateCounts = b.getUpdateCounts();
            for (int i = 0; i < updateCounts.length; i++) {
                System.err.print(updateCounts[i] + " ");
            }
        }
        catch(SQLException ex) {
            System.err.println("SQLException: " + ex.getMessage());
            System.err.println("SQLState: " + ex.getSQLState());
            System.err.println("Message: " + ex.getMessage());
            System.err.println("Vendor error code: " + ex.getErrorCode());
        }
        catch(Exception e) {
            e.printStackTrace();
            System.err.println("Exception: " + e.getMessage());
        }
        finally {
            rs.close();
            stmt.close();
            conn.close();
        }
      }

1 Ответ

0 голосов
/ 27 октября 2011

У вас есть список идентификаторов, которые вас интересуют. Вы можете использовать ограничение ' id в (..., ...,) ':

StringBuilder newIds = new StringBuilder();
ResultSet rs = stmt.getGeneratedKeys();
while (rs.next()) {
  if (newIds.length() > 0)  newIds.append(',');
  newIds.append(rs.getInt(1));
}

if (newIds.length() > ) {
  rs = stmt.executeQuery("SELECT * FROM survey where id in ("+newIds+")");
  ...
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...