Objetivos
En este instructivo, se explican los siguientes pasos con el controlador de SQL o la base de datos de Spanner:
- Crea una base de datos y una instancia 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 deGoogle 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 de base de datos o SQL local
Descarga e instala Go en tu máquina de desarrollo si aún no lo hiciste.
Clona el repositorio de muestra en tu máquina local:
git clone https://github.com/googleapis/go-sql-spanner.git
Ve al directorio que contiene el código de muestra de Spanner:
cd go-sql-spanner/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 que indica cómo usar Spanner con la base de datos/SQL.
Consulta el archivogetting_started_guide.go
, en el que se muestra cómo usar Spanner. El código es un instructivo sobre cómo crear y usar una base de datos nueva. Los datos utilizan el esquema de ejemplo de la página Esquema y modelo de datos.
Crea una base de datos
gcloud spanner databases create example-db --instance=test-instance
Deberías ver lo siguiente:
Creating database...done.
Crear tablas
Con el siguiente código, se crean dos tablas en la base de datos.
Ejecuta la muestra con el siguiente comando:
go run getting_started_guide.go createtables projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
El siguiente paso consiste en escribir datos en tu base de datos.
Crear una conexión
Para realizar operaciones de lectura o escritura, debes crear unsql.DB
. sql.DB
contiene un grupo de conexiones que se puede usar para interactuar con Spanner. El nombre de la base de datos y otras propiedades de conexión se especifican en el nombre de la fuente de datos de la base de datos o SQL.
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 la función ExecContext
para ejecutar una declaración DML.
Ejecuta la muestra con el siguiente comando:
go run getting_started_guide.go dmlwrite projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
El resultado muestra lo siguiente:
4 records inserted.
Escribe datos con mutaciones
También puedes insertar datos mediante mutaciones.
Una Mutation
es un contenedor de operaciones de mutación. Una Mutation
representa una secuencia de inserciones, actualizaciones y eliminaciones que Spanner aplica de forma atómica a diferentes filas y tablas en una base de datos de Spanner.
Usa Mutation.InsertOrUpdate()
para construir una mutación INSERT_OR_UPDATE
, que agrega una fila nueva o actualiza los valores de la columna si la fila ya existe. También puedes usar el método Mutation.Insert()
para construir una mutación INSERT
, que agrega una fila nueva.
conn.Raw
para obtener una referencia a la conexión de Spanner subyacente. La función SpannerConn.Apply
aplica mutaciones atómicas a la base de datos.
En el siguiente código, se muestra cómo escribir los datos mediante mutaciones:
Ejecuta el siguiente ejemplo con el argumento write
:
go run getting_started_guide.go write projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
Consulta datos mediante SQL
Spanner admite una interfaz de SQL para leer datos, a la que puedes acceder desde la línea de comandos con Google Cloud CLI o de manera programática con el controlador de SQL o la base de datos 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
:
gcloud spanner databases execute-sql example-db --instance=test-instance \
--sql='SELECT SingerId, AlbumId, AlbumTitle 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 de SQL o la base de datos 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 de SQL o la base de datos de Spanner.
Las siguientes funciones y estructuras se usan para ejecutar una consulta de SQL:- La función
QueryContext
en la estructuraDB
: úsala para ejecutar una instrucción de SQL que devuelva filas, como una consulta o una instrucción DML con una cláusulaTHEN RETURN
. - La estructura
Rows
: Úsala para acceder a los datos que muestra una instrucción de SQL.
En el siguiente ejemplo, se usa la función QueryContext
:
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go query projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
El resultado muestra lo siguiente:
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 puede almacenarse en caché y volverse a usar, lo que reduce los costos de compilación. Para obtener más información, consulta Usa parámetros de consulta para agilizar 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 contienen un valor específico de LastName
.
El controlador de base de datos/SQL de Spanner admite parámetros de consulta posicionales y con nombre. Un ?
en una sentencia SQL indica un parámetro de consulta posicional. Pasa los valores de los parámetros de consulta como argumentos adicionales a la función QueryContext
. Por ejemplo:
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go querywithparameter projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
El resultado muestra lo siguiente:
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 que la base de datos esté sin conexión y no bloquean tablas ni columnas completas. Puedes continuar escribiendo 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 la CLI de Google Cloud o de manera programática con el controlador de SQL o la base de datos de Spanner.
En la línea de comandos
Usa el siguiente comando ALTER TABLE
para agregar la columna nueva a la tabla:
gcloud spanner databases ddl update example-db --instance=test-instance \
--ddl='ALTER TABLE Albums ADD COLUMN MarketingBudget INT64'
Deberías ver lo siguiente:
Schema updating...done.
Usa el controlador de SQL o la base de datos de Spanner
Usa la funciónExecContext
para modificar el esquema:
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go addcolumn projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
El resultado muestra lo siguiente:
Added MarketingBudget column.
Ejecuta un lote de DDL
Te recomendamos que ejecutes varias modificaciones de esquemas en un lote. Usa
los comandos START BATCH DDL
y RUN BATCH
para ejecutar un lote de DDL. En el siguiente ejemplo, se crean dos tablas en un lote:
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go ddlbatch projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
El resultado muestra 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)
.
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go update projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
El resultado muestra lo siguiente:
Updated 2 albums
También puedes ejecutar una consulta de SQL para obtener los valores que acabas de escribir.
En el siguiente ejemplo, se usa la función QueryContext
para ejecutar una consulta:
Para ejecutar esta consulta, ejecuta el siguiente comando:
go run getting_started_guide.go querymarketingbudget projects/$GCLOUD_PROJECT/instances/test-instance/databases/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.
Llama a DB.BeginTx
para ejecutar transacciones de lectura y escritura en database/sql.
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go writewithtransactionusingdml projects/$GCLOUD_PROJECT/instances/test-instance/databases/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 pasar opciones de transacción adicionales a la función spannerdriver.BeginReadWriteTransaction
.
Usa spannerdriver.ExecOptions
para pasar opciones de consulta adicionales para una sentencia SQL. Por ejemplo:
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go tags projects/$GCLOUD_PROJECT/instances/test-instance/databases/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.
Establece el campo TxOptions.ReadOnly
en true
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:
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go readonlytransaction projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
El resultado muestra lo siguiente:
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
La API de partitionQuery
divide una consulta en partes más pequeñas, o particiones, y usa varias máquinas 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 te permite ejecutar consultas de estadísticas y exportaciones de datos con un impacto casi nulo en las cargas de trabajo existentes de la instancia de Spanner aprovisionada. Data Boost solo admite consultas particionadas.
En el siguiente ejemplo, se muestra cómo ejecutar una consulta particionada con Data Boost con el controlador de base de datos/SQL:
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go databoost projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
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.
Ejecuta el ejemplo con el siguiente comando:
go run getting_started_guide.go pdml projects/$GCLOUD_PROJECT/instances/test-instance/databases/example-db
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 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 Autentícate en servicios de Cloud con bibliotecas cliente.
Obtén más información sobre las prácticas recomendadas de diseño de esquemas de Spanner.