IniziaInizia gratis

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

Visualizza il corso

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));
            }
        }
    }
}
Modifica ed esegui il codice