Lavorare con i Large Objects (LOBs)

Eseguire query su un database PostgreSQL in Java

Miller Trujillo

Staff Software Engineer

Large Objects nei Database

  • BLOB: Oggetto Binario Grande (immagini, video, PDF)
  • CLOB: Oggetto di Testo Grande (testi lunghi, XML, JSON)

Rappresentazione di BLOB e CLOB

Eseguire query su un database PostgreSQL in Java

Perché BLOB e CLOB?

  • VARCHAR funziona per dati piccoli
  • BLOB e CLOB sono per contenuti molto grandi
  • Supportano lo streaming: lettura e scrittura a blocchi

Analogia - streaming di un film

Eseguire query su un database PostgreSQL in Java

Scrivere un BLOB in Java

String sql = "INSERT INTO covers (book_id, image) VALUES (?, ?)";


try (PreparedStatement pstmt = conn.prepareStatement(sql); FileInputStream fis = new FileInputStream("cover.png")) {
pstmt.setInt(1, 101);
pstmt.setBinaryStream(2, fis);
pstmt.executeUpdate();
}
  • INSERT - aggiunge nuove righe a una tabella
  • setBinaryStream() - invia dati binari a una colonna BLOB
Eseguire query su un database PostgreSQL in Java

Scrivere un CLOB in Java

String sql = "INSERT INTO manuscripts (book_id, content) VALUES (?, ?)";

try (PreparedStatement pstmt = conn.prepareStatement(sql);

FileReader reader = new FileReader("manuscript.txt")) {
pstmt.setInt(1, 101);
pstmt.setCharacterStream(2, reader);
pstmt.executeUpdate();
}

setCharacterStream() - invia dati di testo a una colonna CLOB

Eseguire query su un database PostgreSQL in Java

Leggere LOB in Java

  • InputStream legge byte; Reader legge caratteri
  • BLOB: getBinaryStream() restituisce un InputStream
  • CLOB: getCharacterStream() restituisce un Reader
String sql = "SELECT image FROM covers WHERE book_id = ?";
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
    pstmt.setInt(1, 101);
    try (ResultSet rs = pstmt.executeQuery()) {

if (rs.next()) {
try (InputStream is = rs.getBinaryStream("image");
FileOutputStream fos = new FileOutputStream("out.png")){
is.transferTo(fos);
} } } }
Eseguire query su un database PostgreSQL in Java

Leggere CLOB con i Reader

String sql = "SELECT content FROM manuscripts";
try (PreparedStatement pstmt = conn.prepareStatement(sql);
     ResultSet rs = pstmt.executeQuery()) {

while (rs.next()) {
try (Reader reader = rs.getCharacterStream("content")) {
char[] cb = new char[30];
reader.read(cb); // Chars from 0 to 29
reader.read(cb); // Chars from 30 to 59: } } }
Eseguire query su un database PostgreSQL in Java

Best Practice per i LOB

  • 📂 Preferisci memorizzare riferimenti (come URL o percorsi)
  • ⏩ Usa API di streaming (setBinaryStream(), getBinaryStream(), setCharacterStream())
  • 🚫 Evita aggiornamenti frequenti su oggetti molto grandi

$$

$$

Rappresentazione di oggetti grandi

Eseguire query su un database PostgreSQL in Java

Ayo berlatih!

Eseguire query su un database PostgreSQL in Java

Preparing Video For Download...