Objetivos
En este instructivo, se explican los siguientes pasos con el controlador JDBC de Spanner:
- Crear una instancia y una base de datos de Spanner
- Escribe, lee y ejecuta consultas de SQL sobre datos en la base de datos.
- Actualiza el esquema de la base de datos.
- Actualiza los datos mediante una transacción de lectura y escritura.
- Agrega un índice secundario a la base de datos.
- Usa el índice para leer y ejecutar consultas de SQL sobre datos.
- Recupera datos con una transacción de solo lectura.
Costos
En este instructivo, se usa Spanner, que es un componente facturable del en Google Cloud. Para obtener información sobre el costo de usar Spanner, consulta Precios.
Antes de comenzar
Completa los pasos descritos en Configuración, que abarcan la creación y configuración de un proyecto de Google Cloud predeterminado, la facturación, la habilitación de la API de Cloud Spanner y la configuración de OAuth 2.0 para obtener credenciales de autenticación para usar la API de Cloud Spanner.
En especial, asegúrate de ejecutar gcloud auth
application-default login
para configurar tu entorno de desarrollo local con credenciales de autenticación.
Prepara tu entorno local de JDBC
Instala los siguientes componentes en tu máquina de desarrollo si aún no se instalaron:
Clona el repositorio de la app de muestra en tu máquina local:
git clone https://github.com/googleapis/java-spanner-jdbc.git
Ve al directorio que contiene el código de muestra de Spanner:
cd java-spanner-jdbc/samples/snippets
Crea una instancia
Cuando usas Spanner por primera vez, debes crear una instancia, que es una asignación de recursos que usan las bases de datos de Spanner. Cuando creas una instancia, debes elegir una configuración de instancia, que determina dónde se almacenan tus datos y también la cantidad de nodos que se usarán, lo que, a su vez, determina la cantidad de recursos de entrega y almacenamiento de tu instancia.
Ejecuta el siguiente comando para crear una instancia de Spanner en la región.
us-central1
con 1 nodo:
gcloud spanner instances create test-instance --config=regional-us-central1 \
--description="Test Instance" --nodes=1
Ten en cuenta que esto crea una instancia con las siguientes características:
- ID de instancia:
test-instance
- Nombre visible:
Test Instance
- Configuración de la instancia:
regional-us-central1
(la configuración regional almacena datos en una región, mientras que la multirregional distribuye datos en varias regiones; Para obtener más información, consulta Acerca de las instancias. - Recuento de nodos: 1 (
node_count
corresponde a la cantidad de recursos de procesamiento y almacenamiento disponibles para las bases de datos de la instancia; Obtén más información en Nodos y unidades de procesamiento).
Deberías ver lo siguiente:
Creating instance...done.
Examina archivos de muestra
El repositorio de muestras contiene una muestra en la que se indica cómo usar Spanner con JDBC.
Elpom.xml
agrega el controlador JDBC de Spanner al
las dependencias del proyecto y configura el complemento de ensamblado para compilar una
archivo JAR ejecutable con la clase Java que se define en este instructivo.
Compila la muestra a partir del
Directorio samples/snippets
:
mvn package -DskipTests
Crea una base de datos
Para crear una base de datos llamada example-db
en la instancia test-instance
, ejecuta lo siguiente en la línea de comandos:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
createdatabase test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
createpgdatabase test-instance example-db
Deberías ver lo siguiente:
Created database [projects/my-project/instances/test-instance/databases/example-db]
GoogleSQL
PostgreSQL
El siguiente paso consiste en escribir datos en tu base de datos.
Crea una conexión JDBC
Para realizar operaciones de lectura o escritura, debes crear unConnection
. Todas tus interacciones
con Spanner deben pasar por un Connection
. El nombre de la base de datos y otras propiedades se especifican en la URL de conexión de JDBC y en el conjunto java.util.Properties
.
GoogleSQL
PostgreSQL
Para obtener una lista completa de las propiedades admitidas, consulta Propiedades de la URL de conexión
Cada Connection
usa recursos, por lo que se recomienda cerrar las conexiones cuando ya no sean necesarias o usar un grupo de conexiones para volver a usarlas en toda la aplicación.
Obtén más información en la referencia de Javadoc Connection
.
Conecta el controlador JDBC al emulador
Puedes conectar el controlador JDBC al emulador de Spanner de estas dos maneras:
- Configura la variable de entorno
SPANNER_EMULATOR_HOST
. Esto le indica a la Controlador de JDBC para conectar al emulador. La instancia y la base de datos de Spanner en la URL de conexión de JDBC ya deben existir en el emulador. - Agrega
autoConfigEmulator=true
a la URL de conexión. Esto le indica al controlador JDBC que se conecte al emulador y que cree automáticamente la instancia y la base de datos de Spanner en la URL de conexión de JDBC si no existen.
En este ejemplo, se muestra cómo usar la URL de conexión autoConfigEmulator=true
de 12 a 1 con la nueva opción de compresión.
GoogleSQL
PostgreSQL
Escribe datos con DML
Puedes insertar datos mediante el lenguaje de manipulación de datos (DML) en una transacción de lectura y escritura.
Usa el método PreparedStatement.executeUpdate()
para ejecutar una sentencia DML.
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
writeusingdml test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
writeusingdmlpg test-instance example-db
Deberías ver lo siguiente:
4 records inserted.
Cómo escribir datos con un lote de DML
Usa los métodosPreparedStatement#addBatch()
y PreparedStatement#executeBatch()
para ejecutar varias instrucciones DML en un lote.
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
writeusingdmlbatch test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
writeusingdmlbatchpg test-instance example-db
Deberías ver lo siguiente:
3 records inserted.
Escribe datos con mutaciones
También puedes insertar datos mediante mutaciones.
Puedes escribir datos con un objeto Mutation
.
Este objeto Mutation
es un contenedor de operaciones de mutación. Un Mutation
representa una secuencia de inserciones, actualizaciones y eliminaciones que
Se aplica de forma atómica a diferentes filas y tablas en una base de datos de Spanner.
El método newInsertBuilder()
en la clase Mutation
genera una mutación INSERT
, que inserta una fila nueva en una tabla. Si la fila ya existe, la escritura falla. Como alternativa, puedes usar el método newInsertOrUpdateBuilder
para generar una mutación INSERT_OR_UPDATE
, que actualiza los valores de la columna si la fila ya existe.
write()
en la interfaz CloudSpannerJdbcConnection
escribe las mutaciones. Todas las mutaciones en un solo lote se aplican de forma atómica.
Puedes desenredar la interfaz CloudSpannerJdbcConnection
desde un Connection
JDBC de Spanner.
En este código, se muestra cómo escribir los datos mediante mutaciones:
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
write test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
writepg test-instance example-db
Deberías ver lo siguiente:
Inserted 10 rows.
Consulta datos mediante SQL
Spanner admite una interfaz de SQL para leer datos, que puedes en la línea de comandos con Google Cloud CLI programáticamente con el controlador JDBC de Spanner.
En la línea de comandos
Ejecuta la siguiente instrucción de SQL para leer los valores de todas las columnas de la tabla Albums
:
GoogleSQL
gcloud spanner databases execute-sql example-db --instance=test-instance \
--sql='SELECT SingerId, AlbumId, AlbumTitle FROM Albums'
PostgreSQL
gcloud spanner databases execute-sql example-db --instance=test-instance \
--sql='SELECT singer_id, album_id, album_title FROM albums'
El resultado debería ser este:
SingerId AlbumId AlbumTitle
1 1 Total Junk
1 2 Go, Go, Go
2 1 Green
2 2 Forever Hold Your Peace
2 3 Terrified
Usa el controlador JDBC de Spanner
Además de ejecutar una instrucción de SQL en la línea de comandos, puedes emitir la misma instrucción de SQL de manera programática con el controlador JDBC de Spanner.
Se usan los siguientes métodos y clases para ejecutar la consulta en SQL:- El método
createStatement()
en la interfazConnection
: Úsalo para crear un nuevo objeto de sentencia para ejecutar una sentencia de SQL. - Método
executeQuery(String)
de la claseStatement
: usa este método para ejecutar una consulta en una base de datos. - El
Statement
class: Úsalo para ejecutar una cadena de SQL. - El
ResultSet
class: Úsala para acceder a los datos que devuelve una instrucción de SQL.
Aquí se muestra cómo enviar la consulta y acceder a los datos:
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
query test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
querypg test-instance example-db
Deberías ver el siguiente resultado:
1 1 Total Junk
1 2 Go, Go, Go
2 1 Green
2 2 Forever Hold Your Peace
2 3 Terrified
Consulta mediante un parámetro de SQL
Si tu aplicación tiene una consulta que se ejecuta con frecuencia, puedes mejorar su rendimiento parametrizándola. La consulta paramétrica resultante se puede almacenar en caché y volver a usar, lo que reduce los costos de compilación. Para obtener más información, consulta Usa parámetros de consulta para acelerar las consultas que se ejecutan con frecuencia.
Este es un ejemplo del uso de un parámetro en la cláusula WHERE
para
Consultar registros que contengan un valor específico para LastName
.
Usa un java.sql.PreparedStatement
.
para ejecutar una consulta con un parámetro.
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
querywithparameter test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
querywithparameterpg test-instance example-db
Deberías ver el siguiente resultado:
12 Melissa Garcia
Actualiza el esquema de la base de datos
Supongamos que necesitas agregar una columna nueva llamada MarketingBudget
a la tabla Albums
. Para agregar una columna nueva a una tabla existente, es necesario actualizar el esquema de la base de datos. Spanner admite actualizaciones del esquema de una base de datos mientras esta sigue entregando tráfico. Las actualizaciones de esquema no requieren
la base de datos sin conexión y no bloquean tablas ni columnas enteras; puedes continuar
la escritura de datos en la base de datos durante la actualización del esquema. Obtén más información sobre las actualizaciones admitidas del esquema y el rendimiento de los cambios de esquema en Cómo realizar actualizaciones de esquema.
Agrega una columna
Puedes agregar una columna en la línea de comandos con Google Cloud CLI o programáticamente con el controlador del controlador JDBC de Spanner.
En la línea de comandos
Usa el siguiente comando ALTER TABLE
para agregar la columna nueva a la tabla:
GoogleSQL
gcloud spanner databases ddl update example-db --instance=test-instance \
--ddl='ALTER TABLE Albums ADD COLUMN MarketingBudget INT64'
PostgreSQL
gcloud spanner databases ddl update example-db --instance=test-instance \
--ddl='ALTER TABLE albums ADD COLUMN marketing_budget BIGINT'
Deberías ver lo siguiente:
Schema updating...done.
Usa el controlador JDBC de Spanner
Usa el métodoexecute(String)
de la clase java.sql.Statement
para modificar el esquema:
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
addmarketingbudget test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
addmarketingbudgetpg test-instance example-db
Deberías ver lo siguiente:
Added MarketingBudget column.
Ejecuta un lote de DDL
Se recomienda ejecutar varias modificaciones de esquemas en un solo lote. Usa el método addBatch(String)
de java.sql.Statement
para agregar varias instrucciones DDL a un lote.
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
ddlbatch test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
ddlbatchpg test-instance example-db
Deberías ver lo siguiente:
Added Venues and Concerts tables.
Escribe datos en la columna nueva
Con el siguiente código, se escriben datos en la columna nueva. Establece MarketingBudget
en 100000
para la fila marcada por Albums(1, 1)
y en 500000
para la fila marcada por Albums(2, 2)
.
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
update test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
updatepg test-instance example-db
Deberías ver un resultado similar a este:
Updated albums
También puedes ejecutar una consulta de SQL o una llamada de lectura para recuperar los valores que acabas de escribir.
Este es el código para ejecutar la consulta:
GoogleSQL
PostgreSQL
Para ejecutar esta consulta, ejecuta el siguiente comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
querymarketingbudget test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
querymarketingbudgetpg test-instance example-db
Deberías ver lo siguiente:
1 1 100000
1 2 null
2 1 null
2 2 500000
2 3 null
Actualiza datos
Puedes actualizar los datos mediante DML en una transacción de lectura y escritura.
Configura AutoCommit=false
para ejecutar transacciones de lectura y escritura en JDBC.
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
writewithtransactionusingdml test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
writewithtransactionusingdmlpg test-instance example-db
Etiquetas de transacción y de solicitud
Usa etiquetas de transacción y de solicitud para solucionar problemas relacionados con las transacciones y las consultas en Spanner. Puedes configurar etiquetas de transacción y de solicitud en el JDBC con las variables de sesión TRANSACTION_TAG
y STATEMENT_TAG
.
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
tags test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
tagspg test-instance example-db
Recupera datos mediante transacciones de solo lectura
Supongamos que quieres ejecutar más de una lectura en la misma marca de tiempo. En las transacciones de solo lectura, se observa un prefijo coherente del historial de confirmaciones de transacciones, por lo que la aplicación siempre obtiene datos coherentes.
Configura ReadOnly=true
y AutoCommit=false
en un java.sql.Connection
, o usa la instrucción SQL SET TRANSACTION READ ONLY
, para ejecutar una transacción de solo lectura.
A continuación, se muestra cómo ejecutar una consulta y cómo realizar una lectura en la misma transacción de solo lectura:
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
readonlytransaction test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
readonlytransactionpg test-instance example-db
Deberías ver un resultado similar a este:
1 1 Total Junk
1 2 Go, Go, Go
2 1 Green
2 2 Forever Hold Your Peace
2 3 Terrified
2 2 Forever Hold Your Peace
1 2 Go, Go, Go
2 1 Green
2 3 Terrified
1 1 Total Junk
Consultas particionadas y Data Boost
El partitionQuery
La API divide una consulta en partes más pequeñas, o particiones, y usa varias
para recuperar las particiones en paralelo. Cada partición se identifica con un
token de partición. La API de PartitionQuery tiene una latencia más alta que la API de consulta estándar, ya que solo está diseñada para operaciones masivas, como exportar o analizar toda la base de datos.
Data Boost le permite ejecutar consultas de análisis y exportaciones de datos con un en las cargas de trabajo existentes en la instancia aprovisionada de Spanner. Data Boost solo admite consultas particionadas.
GoogleSQL
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
databoost test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
databoostpg test-instance example-db
Obtén más información sobre cómo ejecutar consultas particionadas y cómo usar Data Boost con el controlador de JDBC, consulta:
- GoogleSQL: Data Boost y sentencias de consulta particionadas
- PostgreSQL: Data Boost y instrucciones de consulta particionadas
DML particionado
El lenguaje de manipulación de datos (DML) particionado está diseñado para los siguientes tipos de actualizaciones y eliminaciones masivas:
- Recolección de elementos no usados y limpieza periódicos.
- El restablecimiento de columnas nuevas con valores predeterminados.
PostgreSQL
Ejecuta la muestra con este comando:
GoogleSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
pdml test-instance example-db
PostgreSQL
java -jar target/jdbc-snippets/jdbc-samples.jar \
pdmlpg test-instance example-db
Para obtener más información sobre AUTOCOMMIT_DML_MODE
, consulta los siguientes vínculos:
Limpieza
Para evitar que se apliquen cargos adicionales a tu cuenta de Google Cloud por los recursos que se usaron en este instructivo, descarta la base de datos y borra la instancia que creaste.
Borra la base de datos
Si borras una instancia, se borrarán de forma automática todas las bases de datos que contiene. En este paso, se muestra cómo borrar una base de datos sin borrar una instancia (ten en cuenta que se seguirán generando cargos por la instancia).
En la línea de comandos
gcloud spanner databases delete example-db --instance=test-instance
Usa la consola de Google Cloud
Ve a la página Instancias de Spanner en la consola de Google Cloud.
Haz clic en la instancia.
Haz clic en la base de datos que deseas borrar.
En la página Detalles de la base de datos, haz clic en Borrar.
Confirma que deseas borrar la base de datos y haz clic en Borrar.
Borra la instancia
Si borras una instancia, se descartarán de forma automática todas las bases de datos creadas en ella.
En la línea de comandos
gcloud spanner instances delete test-instance
Usa la consola de Google Cloud
Ve a la página Instancias de Spanner en la consola de Google Cloud.
Haz clic en tu instancia.
Haz clic en Borrar.
Confirma que deseas borrar la instancia y haz clic en Borrar.
¿Qué sigue?
- Obtén información para integrar Spanner con Spring Data JPA (dialecto de GoogleSQL).
- Obtén más información sobre cómo integrar Spanner con Spring Data JPA (dialecto PostgreSQL).
- Obtén información para integrar Spanner con Hibernate ORM (dialecto de GoogleSQL).
- Obtén información para integrar Spanner con Hibernate ORM (dialecto de PostgreSQL).
- Obtén más información sobre los comandos de administración de sesiones de JDBC (GoogleSQL).
- Obtén más información sobre los comandos de administración de sesiones de JDBC (PostgreSQL).
Obtén información para acceder a Spanner con una instancia de máquina virtual.
Obtén más información sobre las credenciales de autorización y autenticación en Autenticar en de Google Cloud con bibliotecas cliente.
Obtén más información sobre las prácticas recomendadas para el diseño de esquemas de Spanner.