sql >> Databasteknik >  >> RDS >> Oracle

Överkomplicerad oracle jdbc BLOB-hantering

Uppdateringsmetoden du nämner i det första fallet kan skrivas om med ren JDBC-kod och därmed minska ditt beroende av Oracle-specifika klasser. Detta kan vara användbart om din app behöver vara databasagnostisk.

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

För MSSQL förstår jag att låssyntaxen är annorlunda:

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


  1. Skickar xml-strängparameter till SQL Server-lagrad procedur

  2. 5 saker att veta om "Windows 10 S"

  3. Skapa profiler i Oracle för användarsäkerhet

  4. Hur kör man en SQL-fråga direkt i C#?