Objetivos
En este instructivo, se explican los siguientes pasos para usar el controlador ADO.NET de Spanner:
- Crea 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 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 Google Cloud predeterminado, la habilitación de 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 ADO.NET
Descarga e instala .NET 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/dotnet-spanner-entity-framework.gitCambia al directorio que contiene el código de muestra del controlador ADO.NET de Spanner:
cd dotnet-spanner-entity-framework/spanner-ado-net/spanner-ado-net-getting-started-guide
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.
Consulta Crea una instancia para obtener información sobre cómo crear una instancia de Spanner con cualquiera de los siguientes métodos. Puedes nombrar tu instancia test-instance para usarla con otros temas de este documento que hacen referencia a una instancia llamada test-instance.
- Google Cloud CLI
- La consola de Google Cloud
- Una biblioteca cliente (C++, C#, Go, Java, Node.js, PHP, Python o Ruby)
Examina archivos de muestra
El repositorio de muestras contiene una muestra que indica cómo usar Spanner con ADO.NET.
Consulta el archivoSampleRunner.cs, 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
GoogleSQL
gcloud spanner databases create example-db --instance=test-instance
PostgreSQL
gcloud spanner databases create example-db --instance=test-instance \
--database-dialect=POSTGRESQL
Deberías ver lo siguiente:
Creating database...done.
Crear tablas
El siguiente código crea dos tablas en la base de datos.
GoogleSQL
PostgreSQL
Ejecuta la muestra con el siguiente comando:
GoogleSQL
dotnet run createtables projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run createtablespg projects/PROJECT_ID/instances/test-instance/databases/example-db
El siguiente paso consiste en escribir datos en tu base de datos.
Crear una conexión
Para poder realizar operaciones de lectura o escritura, debes crear una conexión para interactuar con Spanner. El nombre de la base de datos y otras propiedades de conexión se especifican en la cadena de conexión de ADO.NET.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 DbCommand#ExecuteNonQuery para ejecutar una declaración DML.
GoogleSQL
PostgreSQL
Ejecuta la muestra con el siguiente comando:
GoogleSQL
dotnet run dmlwrite projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run dmlwritepg projects/PROJECT_ID/instances/test-instance/databases/example-db
El resultado debería mostrar lo siguiente:
4 records inserted.
Escribe datos con mutaciones
También puedes insertar datos mediante mutaciones.
Puedes insertar datos con el método batch.CreateInsertCommand(), que crea un SpannerBatchCommand nuevo para insertar filas en una tabla.
El método SpannerBatchCommand.ExecuteNonQueryAsync() agrega filas nuevas a la tabla.
En el siguiente código, se muestra cómo escribir datos con mutaciones:
GoogleSQL
PostgreSQL
Ejecuta el siguiente ejemplo con el argumento write:
GoogleSQL
dotnet run write projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run writepg projects/PROJECT_ID/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 ADO.NET 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 muestra lo siguiente:
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 ADO.NET 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 ADO.NET de Spanner.
Los siguientes métodos se usan para ejecutar una consulta en SQL:- El método
ExecuteReaderde la claseDbCommand: Úsalo para ejecutar una instrucción de SQL que devuelva filas, como una consulta o una declaración DML con una cláusulaTHEN RETURN. - Clase
DbDataReader: Úsala para acceder a los datos que muestra una instrucción de SQL.
En el siguiente ejemplo, se usa el método ExecuteReaderAsync:
GoogleSQL
PostgreSQL
Ejecuta el ejemplo con el siguiente comando:
GoogleSQL
dotnet run query projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run querypg projects/PROJECT_ID/instances/test-instance/databases/example-db
El resultado debería mostrar 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 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 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 para LastName.
El controlador ADO.NET de Spanner admite parámetros de consulta con nombre y posicionales. Un ? en una instrucción de SQL indica un parámetro de consulta posicional. Agrega valores de parámetros de consulta al Parameters de DbCommand. Por ejemplo:
GoogleSQL
PostgreSQL
Ejecuta el ejemplo con el siguiente comando:
GoogleSQL
dotnet run querywithparameter projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run querywithparameterpg projects/PROJECT_ID/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 Realiza actualizaciones de esquema.
Agrega una columna
Puedes agregar una columna en la línea de comandos con Google Cloud CLI o de manera programática con el controlador de ADO.NET 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 ADO.NET de Spanner
Usa el métodoExecuteNonQueryAsync para modificar el esquema:
GoogleSQL
PostgreSQL
Ejecuta el ejemplo con el siguiente comando:
GoogleSQL
dotnet run addcolumn projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run addcolumnpg projects/PROJECT_ID/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 del esquema en un solo lote. Usa el método CreateBatch de ADO.NET para crear un lote. En el siguiente ejemplo, se crean dos tablas en un lote:
GoogleSQL
PostgreSQL
Ejecuta el ejemplo con el siguiente comando:
GoogleSQL
dotnet run ddlbatch projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run ddlbatchpg projects/PROJECT_ID/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).
GoogleSQL
PostgreSQL
Ejecuta el ejemplo con el siguiente comando:
GoogleSQL
dotnet run update projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run updatepg projects/PROJECT_ID/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 el método ExecuteReaderAsync para ejecutar una consulta:
GoogleSQL
PostgreSQL
Para ejecutar esta consulta, ejecuta el siguiente comando:
GoogleSQL
dotnet run querymarketingbudget projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run querymarketingbudgetpg projects/PROJECT_ID/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 connection.BeginTransactionAsync() para ejecutar transacciones de lectura y escritura en ADO.NET.
GoogleSQL
PostgreSQL
Ejecuta el ejemplo con el siguiente comando:
GoogleSQL
dotnet run writewithtransactionusingdml projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run writewithtransactionusingdmlpg projects/PROJECT_ID/instances/test-instance/databases/example-db
Etiquetas de transacción y etiquetas de solicitud
Usa etiquetas de transacción y de solicitud para solucionar problemas relacionados con transacciones y consultas en Spanner. Puedes configurar etiquetas en objetos Transaction para enviar etiquetas de transacción y en objetos DbCommand para enviar etiquetas de solicitud a Spanner. Por ejemplo:
GoogleSQL
PostgreSQL
Ejecuta el ejemplo con el siguiente comando:
GoogleSQL
dotnet run tags projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run tagspg projects/PROJECT_ID/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.
Llama a connection.BeginReadOnlyTransactionAsync() 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 el ejemplo con el siguiente comando:
GoogleSQL
dotnet run readonlytransaction projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run readonlytransactionpg projects/PROJECT_ID/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
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.
GoogleSQL
PostgreSQL
Ejecuta el ejemplo con el siguiente comando:
GoogleSQL
dotnet run pdml projects/PROJECT_ID/instances/test-instance/databases/example-db
PostgreSQL
dotnet run pdmlpg projects/PROJECT_ID/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 más 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.