sql >> Database >  >> RDS >> Oracle

Overgecompliceerde Oracle jdbc BLOB-afhandeling

De update-aanpak die u in het eerste geval noemt, kan worden herschreven met pure JDBC-code en zo uw afhankelijkheid van Oracle-specifieke klassen verminderen. Dit kan handig zijn als uw app database-onafhankelijk moet zijn.

public static void updateBlobColumn(Connection con, String table, String blobColumn, byte[] inputBytes, String idColumn, Long id) throws SQLException {
  PreparedStatement pStmt = null;
  ResultSet rs = null;
  try {
    String sql = 
      " SELECT " + blobColumn + 
      " FROM " + table + 
      " WHERE " + idColumn + " = ? " +
      " FOR UPDATE";
    pStmt = con.prepareStatement(sql, 
      ResultSet.TYPE_FORWARD_ONLY, 
      ResultSet.CONCUR_UPDATABLE);
    pStmt.setLong(1, id);
    rs = pStmt.executeQuery();
    if (rs.next()) {
      Blob blob = rs.getBlob(blobColumn);
      blob.truncate(0);
      blob.setBytes(1, inputBytes);
      rs.updateBlob(blobColumn, blob);
      rs.updateRow();
    }
  }
  finally {
    if(rs != null) rs.close();
    if(pStmt != null) pStmt.close();
  }
}

Voor MSSQL begrijp ik dat de vergrendelingssyntaxis anders is:

String sql = 
  " SELECT " + blobColumn + 
  " FROM " + table + " WITH (rowlock, updlock) " + 
  " WHERE " + idColumn + " = ? "


  1. Probleem met invoegquery in Sqlite? (variabele invoegen)

  2. Opgeslagen procedure die automatisch rijen verwijdert die ouder zijn dan 7 dagen in MYSQL

  3. Complete gids om SQL Database Error 5243 op te lossen

  4. Verwijder rare tekens (A met hoed) uit de SQL Server varchar-kolom