sql >> Databáze >  >> RDS >> Oracle

ORA-00604:došlo k chybě na úrovni rekurzivního SQL 1

Myslím, že PreparedStatement definice by měla být vytažena ze smyčky a znovu použita v rámci smyčky voláním clearParameters :

pstatement = db_connection.prepareStatement(PDSLnPConstants.UPSERT_SQL); // create a statement

for (Entry<Integer, LinkedHashMap<Integer, String>> entry : GUID_ID_MAPPING.entrySet()) {

    pstatement.setInt(1, entry.getKey());
    pstatement.setString(2, entry.getValue().get(PDSLnPConstants.CGUID_ID));
    pstatement.setString(3, entry.getValue().get(PDSLnPConstants.PGUID_ID));
    pstatement.setString(4, entry.getValue().get(PDSLnPConstants.SGUID_ID));
    pstatement.setString(5, entry.getValue().get(PDSLnPConstants.UID_ID));
    pstatement.setString(6, entry.getValue().get(PDSLnPConstants.ULOC_ID));
    pstatement.setString(7, entry.getValue().get(PDSLnPConstants.SLOC_ID));
    pstatement.setString(8, entry.getValue().get(PDSLnPConstants.PLOC_ID));
    pstatement.setString(9, entry.getValue().get(PDSLnPConstants.ALOC_ID));
    pstatement.setString(10, entry.getValue().get(PDSLnPConstants.SITE_ID));
    pstatement.executeUpdate();

    pstatement.clearParameters();

}

Můžete také prozkoumat dávkové zpracování (addBatch ). Pokud testujete, možná budete muset chvíli počkat, než budou vyčištěny stávající „otevřené“ kurzory.



  1. Mohu definovat více událostí v jedné deklaraci Trigger v mysql?

  2. PŘÍPAD SQL:Poznejte a vyhněte se 3 méně známým potížím

  3. Rollup funkce - Nahraďte NULL

  4. MySQL Převeďte data latin1 do UTF8