Integrare Spanner con Hibernate ORM (dialetto GoogleSQL)

Hibernate è uno strumento di mappatura relazionale degli oggetti per il linguaggio di programmazione Java. Fornisce un framework per la mappatura di un modello di dominio orientato agli oggetti a un database relazionale.

Puoi integrare database dialetti GoogleSQL con Hibernate utilizzando lo strumento open source Spanner Dialect (SpannerDialect). Spanner è compatibile con Hibernate ORM 6.3. Spanner Dialect produce istruzioni SQL, DML e DDL per i tipi di entità e le relazioni più comuni utilizzando le annotazioni standard Hibernate e Java Persistence.

Configura ibernazione

Nel progetto, aggiungi le dipendenze di Apache Maven per il core ORM Hibernate, a Spanner Dialect e il driver JDBC open source Spanner ufficialmente supportato.

<dependencies>
  <!-- The Spanner JDBC driver dependency -->
  <dependency>
    <groupId>com.google.cloud</groupId>
    <artifactId>google-cloud-spanner-jdbc</artifactId>
  </dependency>

  <!-- Hibernate core dependency -->
  <dependency>
    <groupId>org.hibernate.orm</groupId>
    <artifactId>hibernate-core</artifactId>
    <version>6.4.4.Final</version>
  </dependency>
</dependencies>

Configura hibernate.cfg.xml per utilizzare il dialetto Spanner e il driver JDBC di Spanner.

<!-- Connection settings -->
<property name="hibernate.dialect">org.hibernate.dialect.SpannerDialect</property>
<property name="hibernate.connection.driver_class">com.google.cloud.spanner.jdbc.JdbcDriver</property>
<property name="hibernate.connection.url">jdbc:cloudspanner:/projects/{YOUR_PROJECT_ID}/instances/{YOUR_INSTANCE_ID}/databases/{YOUR_DATABASE_ID}</property>

La posizione del file delle credenziali JSON dell'account di servizio deve essere nella variabile di ambiente GOOGLE_APPLICATION_CREDENTIALS. In caso contrario, il driver utilizzerà le credenziali predefinite impostate nell'applicazione gcloud di Google Cloud CLI.

Utilizzo di Hibernate con Spanner GoogleSQL

Per ulteriori informazioni sulle funzionalità e sui suggerimenti per Hibernate, consulta la documentazione di riferimento su GitHub.

Passaggi successivi