sql >> Database teknologi >  >> RDS >> Oracle

Overkompliceret oracle jdbc BLOB-håndtering

Den opdateringstilgang, du nævner i det første tilfælde, kan omskrives ved hjælp af ren JDBC-kode og dermed reducere din afhængighed af Oracle-specifikke klasser. Dette kan være nyttigt, hvis din app skal være databaseagnostisk.

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();
  }
}

For MSSQL forstår jeg, at låsesyntaksen er anderledes:

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


  1. Forstå kolonnealias i Select Query i SQL Server - SQL Server / TSQL Selvstudium del 115

  2. Formler til at beregne geografisk nærhed

  3. Er der en RIGTIG ydelsesforskel mellem INT og VARCHAR primære nøgler?

  4. MySQL - Rækker til kolonner