Cette page explique comment créer et gérer des emplacements de données dans Spanner.
Pour en savoir plus sur le fonctionnement du géo-partitionnement, consultez la présentation du géo-partitionnement.
Créer un emplacement de données
Après avoir créé les partitions de votre instance Spanner et les bases de données, créez votre emplacement.
Console
Accédez à la page Instances de la Google Cloud console.
Sélectionnez l'instance avec une ou plusieurs partitions d'instance créées par l'utilisateur.
Sélectionnez la base de données dont vous souhaitez partitionner les données.
Dans le menu de navigation, cliquez sur Spanner Studio.
Sur la page Spanner Studio, cliquez sur Nouvel onglet ou utilisez l'onglet d'éditeur vide.
Saisissez l'instruction LDD
CREATE PLACEMENT(GoogleSQL, PostgreSQL) .Par exemple, vous pouvez exécuter la commande suivante pour créer une table d'emplacement
europeplacementdans la partition d'instanceeurope-partition:GoogleSQL
CREATE PLACEMENT europeplacement OPTIONS (instance_partition="europe-partition");PostgreSQL
CREATE PLACEMENT europeplacement WITH (instance_partition='europe-partition');Facultatif : Vous pouvez également utiliser le volet Explorateur d'objets pour afficher vos objets d'emplacement, effectuer des recherches et interagir avec eux. Pour en savoir plus, consultez la section Explorer vos données.
Cliquez sur Exécuter.
gcloud
Pour créer un emplacement avec la commande Google Cloud CLI, utilisez
gcloud spanner databases ddl update.
Par exemple, créez un emplacement dans la partition d'instance europe-partition :
GoogleSQL
gcloud spanner databases ddl update example-db \
--instance=test-instance \
--ddl="CREATE PLACEMENT europeplacement OPTIONS (instance_partition='europe-partition')"
PostgreSQL
gcloud spanner databases ddl update example-db \
--instance=test-instance \
--ddl="CREATE PLACEMENT europeplacement WITH (instance_partition='europe-partition')"
Définir le leader par défaut pour un emplacement
Vous pouvez définir la région principale par défaut d'un emplacement si celui-ci se trouve dans une région double ou multirégionale. La nouvelle région principale doit être l'une des deux régions en lecture/écriture dans l'emplacement birégional ou multirégional. Pour en savoir plus, consultez les tableaux Configurations disponibles pour les régions doubles et Configurations disponibles pour les régions multiples.
Si vous ne définissez pas de région principale, votre emplacement utilise la région principale par défaut spécifiée par son emplacement. Pour obtenir la liste des régions principales pour chaque
emplacement birégional ou multirégional, consultez les
tableaux Configurations disponibles pour les régions doubles
et Configurations disponibles pour les régions multiples. La région principale par défaut est indiquée par un L. Par exemple, la région principale par défaut de nam8 se trouve à Los Angeles(us-west2). Les instructions suivantes expliquent comment la définir sur l'Oregon(us-west1).
Console
Accédez à la page Instances de la Google Cloud console.
Sélectionnez l'instance avec une ou plusieurs partitions d'instance créées par l'utilisateur.
Sélectionnez la base de données dont vous souhaitez partitionner les données.
Dans le menu de navigation, cliquez sur Spanner Studio.
Sur la page Spanner Studio, cliquez sur Nouvel onglet ou utilisez l'onglet d'éditeur vide.
Saisissez l'instruction LDD
CREATE PLACEMENT(GoogleSQL, PostgreSQL) .Par exemple, vous pouvez exécuter la commande suivante pour créer une table d'emplacement
nam8placementdans la partition d'instancenam8-partitionavec l'emplacement principal par défaut défini surus-west1:GoogleSQL
CREATE PLACEMENT `nam8placement` OPTIONS (instance_partition="nam8-partition", default_leader="us-west1");PostgreSQL
CREATE PLACEMENT nam8placement WITH (instance_partition='nam8-partition', default_leader='us-west1');Facultatif : Vous pouvez également utiliser le volet Explorateur d'objets pour afficher vos objets d'emplacement, effectuer des recherches et interagir avec eux. Pour en savoir plus, consultez la section Explorer vos données.
Cliquez sur Exécuter.
gcloud
Pour créer un emplacement avec la commande gcloud CLI, utilisez
gcloud spanner databases ddl update.
Par exemple, créez une table d'emplacement nam8placement dans la partition d'instance nam8-partition avec l'emplacement principal par défaut défini sur us-west1 :
GoogleSQL
gcloud spanner databases ddl update example-db \
--instance=test-instance \
--ddl="CREATE PLACEMENT nam8placement \
OPTIONS (instance_partition='nam8-partition', default_leader='us-west1')"
PostgreSQL
gcloud spanner databases ddl update example-db \
--instance=test-instance \
--ddl="CREATE PLACEMENT nam8placement WITH (instance_partition='nam8-partition', default_leader='us-west1')"
Supprimer un emplacement de données
Avant de supprimer un emplacement, vous devez supprimer toutes les données de ligne de l'emplacement. Une fois cette opération effectuée, vous pouvez utiliser la Google Cloud console ou gcloud CLI pour supprimer l'emplacement.
Console
- Dans le menu de navigation, cliquez sur Spanner Studio.
- Sur la page Spanner Studio, cliquez sur Nouvel onglet ou utilisez l'onglet d'éditeur vide.
Saisissez l'instruction LDD
DROP PLACEMENT(GoogleSQL, PostgreSQL).Par exemple, vous pouvez exécuter la commande suivante pour supprimer la table d'emplacement
europeplacement:GoogleSQL
DROP PLACEMENT europeplacement;PostgreSQL
DROP PLACEMENT europeplacement;
gcloud
Pour supprimer un emplacement avec la commande gcloud CLI, utilisez gcloud spanner databases ddl update.
Par exemple, supprimez l'emplacement europeplacement :
gcloud spanner databases ddl update example-db \
--instance=test-instance \
--ddl="DROP PLACEMENT europeplacement"
Erreurs de suppression d'emplacement
Si l'emplacement est en cours d'utilisation, l'opération DROP PLACEMENT échoue avec un
message d'erreur tel que "Statement failed: Placement
PLACEMENT_NAME cannot be dropped because it is in use by
placement table PLACEMENT_TABLE_NAME.". Si cette erreur se produit, procédez comme suit :
- Modifiez votre application pour arrêter d'insérer ou de mettre à jour des lignes avec l'emplacement que vous souhaitez supprimer.
L'une des options ci-dessous :
Déplacez les lignes d'emplacement existantes qui utilisent l'emplacement que vous souhaitez supprimer vers un autre emplacement avec une instruction LMD partitionnée comme suit :
UPDATE PLACEMENT_TABLE_NAME SET LOCATION = NEW_PLACEMENT_NAME WHERE LOCATION = ORIGINAL_PLACEMENT_NAME;Supprimez les lignes d'emplacement avec une instruction LMD partitionnée comme suit :
DELETE FROM PLACEMENT_TABLE_NAME WHERE LOCATION = ORIGINAL_PLACEMENT_NAME;Les instructions LMD spécifiques à l'emplacement précédentes ne fonctionnent qu'avec le LMD partitionné. Elles échoueront en tant qu'instructions LMD régulières. Pour en savoir plus, consultez la section Limites. Vous pouvez également utiliser l'API de mutation pour déplacer ou supprimer des lignes d'emplacement.
Annuler une opération DROP PLACEMENT
Vous pouvez annuler une opération DROP PLACEMENT à tout moment avant que l'opération de longue durée ne supprime complètement l'emplacement du schéma de la base de données. Pour savoir comment obtenir l'ID de l'opération de longue durée afin de vérifier l'état ou d'annuler
l'opération, consultez Gérer et observer les opérations de longue durée.
Créer une table avec une clé d'emplacement
Console
- Dans le menu de navigation, cliquez sur Spanner Studio.
- Sur la page Spanner Studio, cliquez Nouvel onglet ou utilisez l'onglet d'éditeur vide.
Saisissez l'instruction LDD
CREATE TABLE(GoogleSQL, PostgreSQL).Par exemple, vous pouvez créer une table
Singersqui utilise une clé d'emplacement pour partitionner les données des chanteurs :GoogleSQL
CREATE TABLE Singers ( SingerId INT64 NOT NULL, SingerName STRING(MAX) NOT NULL, ... Location STRING(MAX) NOT NULL PLACEMENT KEY ) PRIMARY KEY (SingerId);PostgreSQL
CREATE TABLE Singers ( SingerId bigint PRIMARY KEY, SingerName varchar(1024), ... Location varchar(1024) NOT NULL PLACEMENT KEY );
gcloud
Pour créer une table, utilisez
gcloud spanner databases ddl update.
Par exemple, vous pouvez créer une table Singers qui utilise une clé d'emplacement pour partitionner les données des chanteurs :
GoogleSQL
gcloud spanner databases ddl update example-db \
--instance=test-instance \
--ddl="CREATE TABLE Singers ( SingerId INT64 NOT NULL, SingerName STRING(MAX) NOT NULL, Location STRING(MAX) NOT NULL PLACEMENT KEY ) PRIMARY KEY (SingerId);"
PostgreSQL
gcloud spanner databases ddl update example-db \
--instance=test-instance \
--ddl="CREATE TABLE Singers ( SingerId bigint PRIMARY KEY, SingerName varchar(1024), Location varchar(1024) NOT NULL PLACEMENT KEY );"
Modifier une table avec une clé d'emplacement
Vous ne pouvez pas supprimer une clé d'emplacement d'une table. Vous ne pouvez pas non plus ajouter de clé d'emplacement à une table après sa création. Toutefois, vous pouvez utiliser l'
ALTER TABLE (GoogleSQL,
PostgreSQL) instruction LDD pour modifier d'autres champs dans
la table, par exemple en ajoutant et en supprimant des colonnes de clé qui ne sont pas des emplacements.
Supprimer une table avec une clé d'emplacement
Avant de supprimer une table avec une clé d'emplacement, vous devez d'abord :
- Supprimer toutes les lignes de la table d'emplacement.
- Attendre que le
version_retention_periodpour la base de données soit écoulé. Pour en savoir plus, consultez la section Récupération à un moment précis. Ensuite, procédez comme suit :
Console
- Dans le menu de navigation, cliquez sur Spanner Studio.
- Sur la page Spanner Studio, cliquez Nouvel onglet ou utilisez l'onglet d'éditeur vide.
Saisissez l'instruction LDD
DROP TABLE(GoogleSQL, PostgreSQL).Par exemple, supprimez la table
Singers:DROP TABLE Singers;
gcloud
Pour supprimer une table, utilisez
gcloud spanner databases ddl update.
Par exemple, supprimez la table Singers :
gcloud spanner databases ddl update example-db \
--instance=test-instance \
--ddl="DROP TABLE Singers"
Insérer une ligne dans une table d'emplacement
Console
- Dans le menu de navigation, cliquez sur Spanner Studio.
- Sur la page Spanner Studio, cliquez Nouvel onglet ou utilisez l'onglet d'éditeur vide.
Saisissez l'instruction LDD
INSERT INTO(GoogleSQL, PostgreSQL).Par exemple, ajoutez un chanteur, Marc Richards, à la table
Singerset partitionnez-le danseuropeplacement:INSERT INTO Singers(SingerId, SingerName, Location) VALUES (1, 'Marc Richards', 'europeplacement')
gcloud
Pour écrire des données dans une table, utilisez
gcloud spanner rows insert.
Par exemple, ajoutez un chanteur, Marc Richards, à la table Singers et partitionnez-le dans europeplacement :
gcloud spanner rows insert --table=Singers --database=example-db \
--instance=test-instance --data=SingerId=1,SingerName='Marc Richards',Location='europeplacement'
Mettre à jour une ligne dans une table d'emplacement
Console
- Dans le menu de navigation, cliquez sur Spanner Studio.
- Sur la page Spanner Studio, cliquez Nouvel onglet ou utilisez l'onglet d'éditeur vide.
Utilisez le DML ou les mutations pour mettre à jour les données d'une table d'emplacement.
Par exemple, remplacez le nom de
singerid=1dans la tableSingersparCatalina Smith:UPDATE Singers s SET s.name='Catalina Smith' WHERE s.id=1;
gcloud
Pour mettre à jour les données d'une table d'emplacement,
utilisez gcloud spanner rows update.
Par exemple, remplacez le nom de singerid=1 dans la table Singers par Catalina Smith :
gcloud spanner rows update --table=Singers --database=example-db \
--instance=test-instance --data=SingerId=1,SingerName='Catalina Smith'
Déplacer une ligne dans une table d'emplacement
Console
- Créez une partition d'instance et un emplacement si ce n'est pas déjà fait.
- Dans le menu de navigation, cliquez sur Spanner Studio.
- Sur la page Spanner Studio, cliquez Nouvel onglet ou utilisez l'onglet d'éditeur vide.
Utilisez DML ou des mutations pour déplacer les données vers la nouvelle partition d'instance.
Par exemple, déplacez
singerid=1dans la tableSingersversasiaplacement:UPDATE Singers s SET s.location='asiaplacement' WHERE s.id=1;
gcloud
Après avoir créé la partition d'instance et l'emplacement où vous souhaitez déplacer
vos données, utilisez gcloud spanner rows update.
Par exemple, déplacez singerid=1 dans la table Singers vers asiaplacement :
gcloud spanner rows update --table=Singers --database=example-db \
--instance=test-instance --data=SingerId=1,Location='asiaplacement'
Supprimer une ligne dans une table d'emplacement
Console
gcloud
Pour supprimer des données, utilisez gcloud spanner rows delete.
Par exemple, supprimez singerid=1 dans la table Singers :
gcloud spanner rows delete --table=Singers --database=example-db \
--instance=test-instance --keys=1
Interroger les données d'une table d'emplacement
Console
- Dans le menu de navigation, cliquez sur Spanner Studio.
- Sur la page Spanner Studio, cliquez Nouvel onglet ou utilisez l'onglet d'éditeur vide.
Exécutez votre requête.
Par exemple, interrogez la table
Singers:SELECT * FROM Singers s WHERE s.SingerId=1;
gcloud
Pour interroger des données, utilisez gcloud spanner databases execute-sql.
Par exemple, interrogez la table Singers :
gcloud spanner databases execute-sql example-db \
--instance=test-instance \
--sql='SELECT * FROM Singers s WHERE s.SingerId=1'
Étape suivante
En savoir plus sur le géo-partitionnement.
Découvrez comment créer et gérer des partitions d'instance.