Objectifs
Ce tutoriel vous montre comment effectuer les opérations suivantes à l'aide du pilote ADO.NET Spanner :
- Créer une instance et une base de données Spanner
- Écrire ou lire des données dans la base de données, et exécuter des requêtes SQL sur ces données
- Mettre à jour le schéma de base de données
- Mettre à jour les données à l'aide d'une transaction en lecture/écriture
- Ajouter un index secondaire à la base de données
- Utiliser l'index pour lire et exécuter des requêtes SQL sur des données
- Récupérer des données à l'aide d'une transaction en lecture seule
Coûts
Ce tutoriel utilise Spanner, un composant facturable deGoogle Cloud. Pour en savoir plus sur le coût d'utilisation de Spanner, consultez la page Tarifs.
Avant de commencer
Pour obtenir les identifiants d'authentification permettant d'utiliser l'API Cloud Spanner, suivez les étapes décrites dans la section Configuration qui traite des sujets suivants : création et définition d'un projet Google Cloud par défaut, activation de la facturation ainsi que de l'API Cloud Spanner, et configuration d'OAuth 2.0.
Veillez en particulier à exécuter gcloud auth
application-default login pour configurer votre environnement de développement local avec des identifiants d'authentification.
Préparer votre environnement ADO.NET local
Si ce n'est pas déjà fait, téléchargez et installez .NET sur votre ordinateur de développement.
Clonez le dépôt de l'exemple sur votre ordinateur local :
git clone https://github.com/googleapis/dotnet-spanner-entity-framework.gitAccédez au répertoire contenant l'exemple de code du pilote ADO.NET Spanner :
cd dotnet-spanner-entity-framework/spanner-ado-net/spanner-ado-net-getting-started-guide
Créer une instance
Lorsque vous utilisez Spanner pour la première fois, vous devez créer une instance qui alloue les ressources utilisées par les bases de données Spanner. Lorsque vous créez une instance, vous choisissez une configuration d'instance, qui détermine l'emplacement de stockage de vos données et le nombre de nœuds à utiliser. Ce dernier paramètre définit la quantité de ressources disponibles dans votre instance pour le stockage et la diffusion.
Consultez Créer une instance pour savoir comment créer une instance Spanner à l'aide de l'une des méthodes suivantes. Vous pouvez nommer votre instance test-instance pour l'utiliser avec d'autres thèmes de ce document qui font référence à une instance nommée test-instance.
- Google Cloud CLI
- La console Google Cloud
- Une bibliothèque cliente (C++, C#, Go, Java, Node.js, PHP, Python ou Ruby)
Consulter des exemples de fichiers
Le dépôt d'exemples contient un exemple qui montre comment utiliser Spanner avec ADO.NET.
Examinez le fichierSampleRunner.cs, qui montre comment utiliser Spanner. Le code indique comment créer et utiliser une base de données. Les données utilisent l'exemple de schéma présenté sur la page Schéma et modèle de données.
Créer une base de données
GoogleSQL
gcloud spanner databases create example-db --instance=test-instance
PostgreSQL
gcloud spanner databases create example-db --instance=test-instance \
--database-dialect=POSTGRESQL
Vous devriez obtenir le résultat suivant :
Creating database...done.
Créer des tables
Le code suivant crée deux tables dans la base de données.
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
L'étape suivante consiste à écrire des données dans la base de données.
Créer une connexion
Pour pouvoir effectuer des opérations de lecture ou d'écriture, vous devez créer une connexion pour interagir avec Spanner. Le nom de la base de données et les autres propriétés de connexion sont spécifiés dans la chaîne de connexion ADO.NET.GoogleSQL
PostgreSQL
Écrire des données avec le langage LMD
Vous pouvez insérer des données à l'aide du langage de manipulation de données (LMD) dans une transaction en lecture/écriture.
L'exécution d'une instruction LMD s'effectue via la méthode DbCommand#ExecuteNonQuery.
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Le résultat devrait être le suivant :
4 records inserted.
Écrire des données avec des mutations
Vous pouvez également insérer des données à l'aide de mutations.
Vous pouvez insérer des données à l'aide de la méthode batch.CreateInsertCommand(), qui crée une commande SpannerBatchCommand pour insérer des lignes dans une table.
La méthode SpannerBatchCommand.ExecuteNonQueryAsync() ajoute des lignes à la table.
Le code suivant montre comment écrire des données à l'aide de mutations :
GoogleSQL
PostgreSQL
Exécutez l'exemple suivant en utilisant l'argument 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
Interroger des données à l'aide de SQL
Spanner accepte une interface SQL pour la lecture des données. Vous pouvez y accéder en ligne de commande à l'aide de la Google Cloud CLI ou de manière programmatique à l'aide du pilote Spanner ADO.NET.
Sur la ligne de commande
Exécutez l'instruction SQL suivante pour lire les valeurs de toutes les colonnes de la table 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'
Le résultat indique :
SingerId AlbumId AlbumTitle
1 1 Total Junk
1 2 Go, Go, Go
2 1 Green
2 2 Forever Hold Your Peace
2 3 Terrified
Utiliser le pilote ADO.NET Spanner
Vous pouvez non seulement exécuter une instruction SQL en ligne de commande, mais également appliquer la même instruction SQL de manière automatisée à l'aide du pilote Spanner ADO.NET.
Les méthodes suivantes sont utilisées pour exécuter une requête SQL :- Méthode
ExecuteReaderde la classeDbCommand: utilisez cette méthode pour exécuter une instruction SQL qui renvoie des lignes, comme une requête ou une instruction LMD avec une clauseTHEN RETURN. - Classe
DbDataReader: utilisez cette classe pour accéder aux données renvoyées par une instruction SQL.
L'exemple suivant utilise la méthode ExecuteReaderAsync :
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Le résultat devrait être le suivant :
1 1 Total Junk
1 2 Go, Go, Go
2 1 Green
2 2 Forever Hold Your Peace
2 3 Terrified
Requête utilisant un paramètre SQL
Si votre application exécute fréquemment une requête, vous pouvez améliorer ses performances en la paramétrant. La requête paramétrique obtenue peut être mise en cache et réutilisée, ce qui réduit les coûts de compilation. Pour en savoir plus, consultez Utiliser des paramètres de requête pour accélérer les requêtes fréquemment exécutées.
Voici un exemple d'utilisation d'un paramètre dans la clause WHERE pour interroger des enregistrements contenant une valeur spécifique pour LastName.
Le pilote Spanner ADO.NET est compatible avec les paramètres de requête positionnels et nommés. Un ? dans une instruction SQL indique un paramètre de requête positionnel. Ajoutez des valeurs de paramètre de requête au Parameters du DbCommand. Exemple :
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Le résultat indique :
12 Melissa Garcia
Mettre à jour le schéma de base de données
Supposons que vous deviez ajouter la colonne MarketingBudget à la table Albums. L'ajout d'une colonne à une table existante nécessite une mise à jour du schéma de base de données. Spanner permet de mettre à jour le schéma d'une base de données pendant que celle-ci continue de diffuser du trafic. Les mises à jour du schéma ne nécessitent pas la mise hors connexion de la base de données et ne verrouillent pas des tables ou des colonnes entières. Vous pouvez continuer à écrire des données dans la base de données pendant ces mises à jour. Pour en savoir plus sur les mises à jour de schéma acceptées et sur les performances liées aux modifications de schéma, consultez Effectuer des mises à jour de schéma.
Ajouter une colonne
Vous pouvez ajouter une colonne sur la ligne de commande à l'aide de la Google Cloud CLI ou de manière automatisée à l'aide du pilote Spanner ADO.NET.
Sur la ligne de commande
Pour ajouter la colonne à la table, utilisez la commande ALTER TABLE suivante :
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'
Vous devriez obtenir le résultat suivant :
Schema updating...done.
Utiliser le pilote ADO.NET Spanner
Utilisez la méthodeExecuteNonQueryAsync pour modifier le schéma :
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Le résultat indique :
Added MarketingBudget column.
Exécuter un lot LDD
Nous vous recommandons d'exécuter plusieurs modifications de schéma dans un même lot. Utilisez la méthode CreateBatch d'ADO.NET pour créer un lot. L'exemple suivant crée deux tables dans un même lot :
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Le résultat indique :
Added Venues and Concerts tables.
Écrire des données dans la nouvelle colonne
Le code ci-dessous permet d'écrire des données dans la nouvelle colonne. Il définit MarketingBudget sur 100000 pour la ligne correspondant à la clé Albums(1, 1) et sur 500000 pour la ligne correspondant à la clé Albums(2, 2).
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Le résultat indique :
Updated 2 albums
Vous pouvez également exécuter une requête SQL pour récupérer les valeurs que vous venez d'écrire.
L'exemple suivant utilise la méthode ExecuteReaderAsync pour exécuter une requête :
GoogleSQL
PostgreSQL
Pour exécuter cette requête, exécutez la commande suivante :
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
Vous devriez obtenir le résultat suivant :
1 1 100000
1 2 null
2 1 null
2 2 500000
2 3 null
Mettre à jour des données
Vous pouvez mettre à jour des données à l'aide du langage LMD dans une transaction en lecture/écriture.
Appelez connection.BeginTransactionAsync() pour exécuter des transactions en lecture-écriture dans ADO.NET.
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Tags de transaction et tags de requête
Utilisez les tags de transaction et de requête pour résoudre les problèmes liés aux transactions et aux requêtes dans Spanner. Vous pouvez définir des tags sur les objets Transaction pour envoyer des tags de transaction, et sur les objets DbCommand pour envoyer des tags de requête à Spanner. Exemple :
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Récupérer des données à l'aide de transactions en lecture seule
Supposons que vous souhaitiez exécuter plusieurs opérations de lecture avec le même horodatage. Les transactions en lecture seule tiennent compte d'un préfixe cohérent de l'historique de commit des transactions, de sorte que votre application obtienne toujours des données cohérentes.
Appelez connection.BeginReadOnlyTransactionAsync() pour exécuter une transaction en lecture seule.
L'exemple ci-dessous montre comment exécuter une requête et effectuer une lecture dans la même transaction en lecture seule.
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Le résultat indique :
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
Les transactions à LMD partitionné
Le langage de manipulation de données (LMD) partitionné est conçu pour les types de mises à jour et de suppressions groupées suivants :
- Nettoyage périodique et récupération de mémoire.
- Remplissage de nouvelles colonnes avec des valeurs par défaut.
GoogleSQL
PostgreSQL
Exécutez l'exemple à l'aide de la commande suivante :
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
Nettoyage
Pour éviter que des frais supplémentaires ne soient facturés sur votre compte Cloud Billing pour les ressources utilisées dans ce tutoriel, supprimez la base de données et l'instance que vous avez créées.
Supprimer la base de données
Si vous supprimez une instance, toutes les bases de données qu'elle contient sont automatiquement supprimées. Cette étape montre comment supprimer une base de données sans supprimer l'instance. Des frais continueront à vous être facturés pour cette dernière.
Sur la ligne de commande
gcloud spanner databases delete example-db --instance=test-instance
Utiliser la console Google Cloud
Accédez à la page Instances Spanner de la console Google Cloud .
Cliquez sur l'instance.
Cliquez sur la base de données que vous souhaitez supprimer.
Sur la page Détails de la base de données, cliquez sur Supprimer.
Confirmez que vous souhaitez supprimer la base de données, puis cliquez sur Supprimer.
Supprimer l'instance
La suppression d'une instance supprime automatiquement toutes les bases de données créées dans cette instance.
Sur la ligne de commande
gcloud spanner instances delete test-instance
Utiliser la console Google Cloud
Accédez à la page Instances Spanner de la console Google Cloud .
Cliquez sur votre instance.
Cliquez sur Supprimer.
Confirmez que vous souhaitez supprimer l'instance, puis cliquez sur Supprimer.
Étapes suivantes
Découvrez comment accéder à Spanner avec une instance de machine virtuelle.
Pour en savoir plus sur les identifiants d'autorisation et d'authentification, consultez S'authentifier auprès de services cloud à l'aide de bibliothèques clientes.
En savoir plus sur les bonnes pratiques de conception de schémas dans Spanner