Eseguire comandi SQL con Hibernate e Java


Come eseguire comandi SQL con estrema flessibilità grazie a Hibernate e Java. Potrai gestire i tuoi database da professionista dello sviluppo
di Antonio Lamorgese


Ciao a tutti, futuri programmatori Java e appassionati del coding! Oggi ci immergeremo nell’entusiasmante mondo di Hibernate in Java. Riuscendo finalmente a capire come eseguire comandi SQL con Hibernate e Java senza scrivere una sola riga di codice SQL. Se sei uno studente o un principiante nel vasto universo della programmazione, sei nel posto giusto. Prendi il tuo cappuccino o la tua bevanda preferita e preparati a scoprire come queste potenti tecnologie possono aiutarti a creare applicazioni dinamiche e sofisticate.

1. Introduzione a Java e Hibernate

Ehi, sono proprio io, il tuo compagno di avventure nel coding! Prima di iniziare, lascia che ti dia una rapida panoramica. Java è un linguaggio di programmazione versatile e ampiamente utilizzato che ti permette di creare software robusto e performante. Hibernate, d’altra parte, è un framework che semplifica l’interazione tra le tue applicazioni Java e il database. In pratica, Hibernate traduce i comandi SQL in linguaggio Java, risparmiandoti un sacco di lavoro!

2. Primi Passi con Java

Prima di iniziare questo viaggio nel mondo della persistenza dei dati in Java è necessario che tu sappia implementare il tuo ambiente per sviluppare in Java. Quindi, devi installare Netbeans, di conseguenza prima di procedere leggi questa breve guida. Allora, sei pronto a scrivere il tuo primo codice Java? Immagina di voler creare un semplice programma che stampi il famosissimo messaggio “Hello world…!” cioè “Ciao, mondo!” sulla console di output. Ecco come si fa: Apri Netbeans, crea un tuo progetto Java Application, copia e incolla questo codice all’interno del metodo main che Netbeans ti ha proposto per default.


public class PrimoProgramma {
    public static void main(String[] args) {
        System.out.println("Hello, World...!");
    }
}

Ecco fatto! Non è difficile, vero? Abbiamo dichiarato una classe chiamata PrimoProgramma e al suo interno abbiamo il metodo main, che è il punto di ingresso del nostro programma e di qualunque programma Java. Il codice all’interno del metodo main stampa il messaggio “Ciao, mondo!” sulla console. Per eseguirlo ti basta cliccare sull’icona raffigurante una freccia verde e verificare la corretta esecuzione nella console di output.


Comandi SQL - Ciao Mondo in Java con Netbeans
Ciao Mondo in Java con Netbeans

3. Introduzione a Hibernate

Ora che hai messo le mani su Java, passiamo a Hibernate. Hibernate è un’insieme di tipi e costrutti racchiusi in un file con estensione “jar” che devi scaricare, cliccando su questo link, e includere nel folder “Libraries” del tuo progetto Java.


Comandi SQL - Aggiungi Hibernate al tuo progetto Java
Aggiungi Hibernate al tuo progetto Java

Tieni presente che Hibernate può essere aggiunto a qualsiasi progetto Java, sia esso una WebApplication sia una Desktop Application o un’applicazione Java Console. Ora, immagina di voler memorizzare informazioni su utenti in un database. Quindi, diamo per scontato che tu abbia un database con la tabella “utenti” presente al suo interno. Hibernate semplifica notevolmente il processo.

Innanzitutto Hibernate per accedere ad un database ha bisogno di tutte le informazioni di accesso ad esso. Queste informazioni vengono memorizzate in un file di configrazione chiamato “hibernate.cfg.xml“. Questo file, creato nella root del tuo progetto java, solitamente il file “hibernate.cfg.xml” viene posizionato nella cartella “Configuration Files“.


Comandi SQL - Percorso di memorizzazione del file di configurazione di Hibernate
Percorso di memorizzazione del file di configurazione di Hibernate

Il file di configurazione di Hibernate ha più o meno questo aspetto:


<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
 "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <!-- Configurazione del driver JDBC -->
        <property name="hibernate.connection.driver_class">com.mysql.cj.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/Test?serverTimezone=UTC</property>
        <property name="hibernate.connection.username">username</property>
        <property name="hibernate.connection.password">password</property>
        
        <!-- Configurazione di Hibernate -->
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        <property name="hibernate.hbm2ddl.auto">update</property>
        <property name="hibernate.show_sql">true</property>
        
        <!-- Mappaggio delle classi -->
        <mapping class="Utente"/>
    </session-factory>
</hibernate-configuration>

Dal contenuto del file si evince che: il database a cui Hibernate tenterà di accedere è “Test“, che il driver utilizzato è “MySQL” e che, la tabella “utenti” è mappata nella classe “Utente“. Dopo aver creato il file di configurazione, Hibernate lo utilizzerà automaticamente per accedere a tutti i parametri di accesso al database “Test“.

Terminata la configurazione del file di Hibernate, per gestire ogni cosa sulla tabella “utenti” del database non ti rimane che creare una classe Java annotata opportunamente e che contiene il mapping di ogni colonna della tabella. Ecco un assaggio:


@Entity
@Table(name = "utenti")
public class Utente {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    @Column(name = "nome")
    private String nome;
    @Column(name = "cognome")
    private String cognome;
    // Getter e setter per impostare e leggere
    // le proprietà "nome" e "cognome"
}

Qui abbiamo definito una classe Utente che rappresenta la tabella “utenti” nel database. Con le annotazioni come @Entity, @Table e @Column, diciamo a Hibernate come mappare le proprietà della classe ai campi del database. Magico, vero?


Leggi anche: Il segreto per scrivere Query SQL


4. I tuoi primi comandi SQL: Gestire banche dati con Hibernate

Ora che sappiamo cosa è Hibernate e come definire entità, come possiamo usarlo in un’applicazione Java? Ti ricordi la tua prima applicazione Java? Quella utilizzata per stampare a video il messaggio “Hello World…!”. Bene. Ora, copia e incolla il codice, riportato di seguito, nel metodo “main“.

Ecco un piccolo esempio:

public class PrimoProgramma {
    public static void main(String[] args) {
        SessionFactory sessionFactory = new Configuration()
            .configure("hibernate.cfg.xml")
            .addAnnotatedClass(Utente.class)
            .buildSessionFactory();
        Session session = sessionFactory.getCurrentSession();
        try {
            // Inizia una transazione
            session.beginTransaction();
            // Crea un nuovo utente
            Utente nuovoUtente = new Utente("Mario", "Rossi");
            session.save(nuovoUtente);
            // Commit della transazione
            session.getTransaction().commit();
        } finally {
            sessionFactory.close();
        }
    }
}

In questo esempio, abbiamo creato una semplice applicazione Java che utilizza Hibernate per salvare un nuovo utente nel database. SessionFactory è il punto di partenza per l’interazione con Hibernate, e utilizziamo session per iniziare e confermare la transazione. Tutto qui. Come hai potuto notare non sono stati digitati comandi SQL per gestire i dati della tabella “utenti“. Hibernate si è occupato di tutto.



Leggi anche: Diventa sviluppatore software con Netbeans


5. Conclusione

Eccoci arrivati alla fine del nostro giro introduttivo nel mondo di Java e Hibernate. Spero che tu abbia trovato questo viaggio utile e stimolante! Abbiamo appena grattato la superficie di queste tecnologie potenti e complesse, ma non preoccuparti se alcune cose sembrano ancora un po’ sfocate. La programmazione è un’arte che richiede pratica costante, e con il tempo diventerai sempre più abile.

Ecco a te, un affettuoso saluto dal mondo di Java e Hibernate! Non smettere mai di imparare, esplorare e creare. E ricorda, sono qui per aiutarti ogni volta che vuoi immergerti nuovamente in questo emozionante viaggio nel coding.

Domande frequenti

1. Come posso creare una classe “Utente” e mapparla a una tabella nel database utilizzando Hibernate?

Puoi creare una classe Java chiamata “Utente” con attributi corrispondenti alle colonne della tabella nel database. Utilizzando le annotazioni di Hibernate come @Entity, @Table e @Column, puoi definire come mappare i campi della classe alle colonne del database. Ad esempio, puoi annotare l’attributo “nome” con @Column(name = "nome") per indicare che è associato alla colonna “nome” nella tabella.

2. Qual è il ruolo di hibernate.cfg.xml nella configurazione di Hibernate?

Il file hibernate.cfg.xml è un file di configurazione di Hibernate che contiene le informazioni essenziali per stabilire una connessione al database, come il driver JDBC, l’URL del database, le credenziali di accesso, il dialetto SQL e altre opzioni di configurazione. Questo file definisce anche come Hibernate deve comportarsi rispetto alla creazione delle tabelle e altri aspetti dell’interazione con il database.

3. Come posso utilizzare Hibernate per salvare dati nel database da una classe Java?

Per utilizzare Hibernate per salvare dati nel database, dovrai seguire alcuni passaggi chiave. Innanzitutto, crea un oggetto della classe mappata (come la classe “Utente” nell’esempio) e assegna i valori appropriati agli attributi. Poi, crea una SessionFactory utilizzando la configurazione da hibernate.cfg.xml. Apri una sessione utilizzando la SessionFactory, inizia una transazione con session.beginTransaction(), salva l’oggetto con session.save(oggetto), e infine conferma la transazione con session.getTransaction().commit(). Non dimenticare di chiudere la sessione e la SessionFactory quando hai finito.

Antonio Lamorgese

Amministratore di rete e sviluppatore. Dopo anni di esperienza nel settore, ho ideato un sistema di gestione dati MYSQL in PHP senza scrivere una sola riga di codice. Scopri di più....