Lettura di capitoli di esempio
La funzione "Prova prima di prendere in prestito" della Metropolitan Public Library sta memorizzando correttamente i capitoli di esempio. Ora devi implementare la funzionalità di recupero così che gli utenti possano effettivamente leggere queste anteprime sul sito della biblioteca.
Poiché i capitoli di esempio possono contenere migliaia di caratteri, userai lo streaming per leggere i dati in modo efficiente. Invece di caricare interi capitoli in memoria tutti insieme, li leggerai a piccoli blocchi usando un buffer di caratteri.
Questo esercizio fa parte del corso
Eseguire query su un database PostgreSQL in Java
Istruzioni dell'esercizio
- Leggi lo stream dal result set per la colonna
sample_chapter. - Imposta la dimensione del buffer per leggere 30 caratteri.
Esercizio pratico interattivo
Prova a risolvere questo esercizio completando il codice di esempio.
public class Main {
public static void main(String[] args) throws SQLException, IOException, ClassNotFoundException {
HikariDataSource ds = HikariSetup.createDataSource();
String query = """
SELECT book_id, sample_chapter FROM book_content bc
""";
try (Connection conn = ds.getConnection();
PreparedStatement pstmt = conn.prepareStatement(query);
ResultSet rs = pstmt.executeQuery()) {
while (rs.next()) {
// Read the stream from the result set
____ reader = rs.____("sample_chapter");
// Read the first 30 characters
char[] cb = new ____[____];
reader.read(cb);
System.out.printf("Book Id: %d, sample chapter: %s ...\n", rs.getInt("book_id"), new String(cb));
}
}
}
}