Créer et gérer des bases de données
Restez organisé à l'aide des collections
Enregistrez et classez les contenus selon vos préférences.
Cette page explique comment créer, répertorier et supprimer des bases de données PostgreSQL sur une instance Cloud SQL.
Une nouvelle instance possÚde une base de données postgres
.
Pour en savoir plus sur les bases de données PostgreSQL, consultez la
documentation PostgreSQL.
Avant de commencer
Avant d'effectuer les tùches indiquées sur cette page :
Si vous prévoyez de créer ou de gérer vos bases de données à l'aide du client psql, vous devez avoir :
Créer une base de données sur l'instance Cloud SQL
Console
-
Dans la console Google Cloud , accédez à la page Instances Cloud SQL.
Accéder à la page Instances Cloud SQL
-
Pour ouvrir la page Présentation d'une instance, cliquez sur son nom.
- Dans le menu de navigation SQL, sélectionnez Bases de données.
- Cliquez sur Create database.
- Dans la boßte de dialogue Nouvelle base de données, spécifiez le nom de la base de données.
- Cliquez sur Créer.
gcloud
Pour plus d'informations, consultez la page sur gcloud
sql databases create
.
gcloud sql databases create DATABASE_NAME \
--instance=INSTANCE_NAME
Pour créer une base de données, utilisez une ressource Terraform.
Appliquer les modifications
Pour appliquer votre configuration Terraform dans un projet Google Cloud , suivez les procédures des sections suivantes.
Préparer Cloud Shell
- Lancez Cloud Shell.
-
Définissez le projet Google Cloud par défaut dans lequel vous souhaitez appliquer vos configurations Terraform.
Vous n'avez besoin d'exécuter cette commande qu'une seule fois par projet et vous pouvez l'exécuter dans n'importe quel répertoire.
export GOOGLE_CLOUD_PROJECT=PROJECT_ID
Les variables d'environnement sont remplacées si vous définissez des valeurs explicites dans le fichier de configuration Terraform.
Préparer le répertoire
Chaque fichier de configuration Terraform doit avoir son propre répertoire (également appelé module racine).
-
Dans Cloud Shell, créez un répertoire et un nouveau fichier dans ce répertoire. Le nom du fichier doit comporter l'extension
.tf
, par exemple main.tf
. Dans ce tutoriel, le fichier est appelé main.tf
.
mkdir DIRECTORY && cd DIRECTORY && touch main.tf
-
Si vous suivez un tutoriel, vous pouvez copier l'exemple de code dans chaque section ou étape.
Copiez l'exemple de code dans le fichier main.tf
que vous venez de créer.
Vous pouvez également copier le code depuis GitHub. Cela est recommandé lorsque l'extrait Terraform fait partie d'une solution de bout en bout.
- Examinez et modifiez les exemples de paramĂštres Ă appliquer Ă votre environnement.
- Enregistrez les modifications.
-
Initialisez Terraform. Cette opération n'est à effectuer qu'une seule fois par répertoire.
terraform init
Vous pouvez également utiliser la derniÚre version du fournisseur Google en incluant l'option -upgrade
:
terraform init -upgrade
Appliquer les modifications
-
Examinez la configuration et vérifiez que les ressources que Terraform va créer ou mettre à jour correspondent à vos attentes :
terraform plan
Corrigez les modifications de la configuration si nécessaire.
-
Appliquez la configuration Terraform en exécutant la commande suivante et en saisissant
yes
lorsque vous y ĂȘtes invitĂ© :
terraform apply
Attendez que Terraform affiche le message "Apply completed!" (Application terminée).
- Ouvrez votre projet Google Cloud pour afficher les résultats. Dans la console Google Cloud , accédez à vos ressources dans l'interface utilisateur pour vous assurer que Terraform les a créées ou mises à jour.
Supprimer les modifications
Pour supprimer vos modifications, procédez comme suit :
- Pour désactiver la protection contre la suppression, définissez l'argument
deletion_protection
sur false
dans le fichier de configuration Terraform.
deletion_protection = "false"
- Appliquez la configuration Terraform mise à jour en exécutant la commande suivante et en saisissant
yes
lorsque vous y ĂȘtes invitĂ© :
terraform apply
-
Supprimez les ressources précédemment appliquées à votre configuration Terraform en exécutant la commande suivante et en saisissant yes
Ă la requĂȘte :
terraform destroy
REST v1
La requĂȘte suivante exĂ©cute la mĂ©thode databases:insert pour crĂ©er une base de donnĂ©es sur l'instance spĂ©cifiĂ©e.
Avant d'utiliser les donnĂ©es de requĂȘte, effectuez les remplacements suivants :
- project-id : ID du projet
- instance-id : ID de l'instance.
- database-name : nom d'une base de données dans l'instance Cloud SQL.
Méthode HTTP et URL :
POST https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases
Corps JSON de la requĂȘte :
{
"project": "project-id",
"instance": "instance-id",
"name": "database-name"
}
Pour envoyer votre requĂȘte, dĂ©veloppez l'une des options suivantes :
curl (Linux, macOS ou Cloud Shell)
Enregistrez le corps de la requĂȘte dans un fichier nommĂ© request.json
, puis exécutez la commande suivante :
curl -X POST \
-H "Authorization: Bearer $(gcloud auth print-access-token)" \
-H "Content-Type: application/json; charset=utf-8" \
-d @request.json \
"https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases"
PowerShell (Windows)
Enregistrez le corps de la requĂȘte dans un fichier nommĂ© request.json
, puis exécutez la commande suivante :
$cred = gcloud auth print-access-token
$headers = @{ "Authorization" = "Bearer $cred" }
Invoke-WebRequest `
-Method POST `
-Headers $headers `
-ContentType: "application/json; charset=utf-8" `
-InFile request.json `
-Uri "https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases" | Select-Object -Expand Content
Vous devriez recevoir une réponse JSON de ce type :
Réponse
{
"kind": "sql#operation",
"targetLink": "https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id",
"status": "PENDING",
"user": "user@example.com",
"insertTime": "2020-01-21T22:43:37.981Z",
"operationType": "CREATE_DATABASE",
"name": "operation-id",
"targetId": "instance-id",
"selfLink": "https://sqladmin.googleapis.com/v1/projects/project-id/operations/operation-id",
"targetProject": "project-id"
}
REST v1beta4
La requĂȘte suivante exĂ©cute la mĂ©thode databases:insert pour crĂ©er une base de donnĂ©es sur l'instance spĂ©cifiĂ©e.
Avant d'utiliser les donnĂ©es de requĂȘte, effectuez les remplacements suivants :
- project-id : ID du projet
- instance-id : ID de l'instance.
- database-name : nom d'une base de données dans l'instance Cloud SQL.
Méthode HTTP et URL :
POST https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases
Corps JSON de la requĂȘte :
{
"project": "project-id",
"instance": "instance-id",
"name": "database-name"
}
Pour envoyer votre requĂȘte, dĂ©veloppez l'une des options suivantes :
curl (Linux, macOS ou Cloud Shell)
Enregistrez le corps de la requĂȘte dans un fichier nommĂ© request.json
, puis exécutez la commande suivante :
curl -X POST \
-H "Authorization: Bearer $(gcloud auth print-access-token)" \
-H "Content-Type: application/json; charset=utf-8" \
-d @request.json \
"https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases"
PowerShell (Windows)
Enregistrez le corps de la requĂȘte dans un fichier nommĂ© request.json
, puis exécutez la commande suivante :
$cred = gcloud auth print-access-token
$headers = @{ "Authorization" = "Bearer $cred" }
Invoke-WebRequest `
-Method POST `
-Headers $headers `
-ContentType: "application/json; charset=utf-8" `
-InFile request.json `
-Uri "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases" | Select-Object -Expand Content
Vous devriez recevoir une réponse JSON de ce type :
Réponse
{
"kind": "sql#operation",
"targetLink": "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id",
"status": "PENDING",
"user": "user@example.com",
"insertTime": "2020-01-21T22:43:37.981Z",
"operationType": "CREATE_DATABASE",
"name": "operation-id",
"targetId": "instance-id",
"selfLink": "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/operations/operation-id",
"targetProject": "project-id"
}
Client psql
Pour en savoir plus, consultez la section CREATE DATABASE de la documentation PostgreSQL.
Consultez les sujets suivants dans la documentation PostgreSQL pour obtenir des informations générales et une liste des valeurs de jeux de caractÚres compatibles :
CREATE DATABASE database_name
[[ ENCODING encoding ][ LC_COLLATE lc_collate ]];
Exemple :
CREATE DATABASE "example_db" WITH OWNER "example_user"
ENCODING 'UTF8' LC_COLLATE = 'pl_PL.utf8' LC_CTYPE = 'pl_PL.utf8' TEMPLATE template0;
Lister les bases de données
Pour répertorier toutes les bases de données d'une instance :
Console
-
Dans la console Google Cloud , accédez à la page Instances Cloud SQL.
Accéder à la page Instances Cloud SQL
-
Pour ouvrir la page Présentation d'une instance, cliquez sur son nom.
- Cliquez sur Bases de données dans le menu de gauche. La page Bases de données répertorie les bases de données ainsi que leur type de classement, leur jeu de caractÚres et leur type de base de données.
gcloud
Pour plus d'informations, consultez la page sur gcloud
sql databases list
.
gcloud sql databases list \
--instance=INSTANCE_NAME
REST v1
La requĂȘte suivante exĂ©cute la mĂ©thode databases:list pour rĂ©pertorier les bases de donnĂ©es d'une instance.
Lorsque vous répertoriez les bases de données à l'aide de l'API, vous voyez des bases de données de modÚles supplémentaires ainsi qu'une base de données systÚme qui ne sont pas affichées par la console. Vous ne pouvez pas supprimer ni gérer la base de données systÚme.
Avant d'utiliser les donnĂ©es de requĂȘte, effectuez les remplacements suivants :
- project-id : ID du projet
- instance-id : ID de l'instance.
Méthode HTTP et URL :
GET https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases
Pour envoyer votre requĂȘte, dĂ©veloppez l'une des options suivantes :
curl (Linux, macOS ou Cloud Shell)
Exécutez la commande suivante :
curl -X GET \
-H "Authorization: Bearer $(gcloud auth print-access-token)" \
"https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases"
PowerShell (Windows)
Exécutez la commande suivante :
$cred = gcloud auth print-access-token
$headers = @{ "Authorization" = "Bearer $cred" }
Invoke-WebRequest `
-Method GET `
-Headers $headers `
-Uri "https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases" | Select-Object -Expand Content
Vous devriez recevoir une réponse JSON de ce type :
Réponse
{
"kind": "sql#database",
"charset": "utf8",
"collation": "utf8_general_ci",
"etag": "etag",
"name": "sys",
"instance": "instance-id",
"selfLink": "https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases/sys",
"project": "project-id"
}
REST v1beta4
La requĂȘte suivante exĂ©cute la mĂ©thode databases:list pour rĂ©pertorier les bases de donnĂ©es d'une instance.
Lorsque vous répertoriez les bases de données à l'aide de l'API, vous voyez des bases de données de modÚles supplémentaires ainsi qu'une base de données systÚme qui ne sont pas affichées par la console. Vous ne pouvez pas supprimer ni gérer la base de données systÚme.
Avant d'utiliser les donnĂ©es de requĂȘte, effectuez les remplacements suivants :
- project-id : ID du projet
- instance-id : ID de l'instance.
Méthode HTTP et URL :
GET https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases
Pour envoyer votre requĂȘte, dĂ©veloppez l'une des options suivantes :
curl (Linux, macOS ou Cloud Shell)
Exécutez la commande suivante :
curl -X GET \
-H "Authorization: Bearer $(gcloud auth print-access-token)" \
"https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases"
PowerShell (Windows)
Exécutez la commande suivante :
$cred = gcloud auth print-access-token
$headers = @{ "Authorization" = "Bearer $cred" }
Invoke-WebRequest `
-Method GET `
-Headers $headers `
-Uri "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases" | Select-Object -Expand Content
Vous devriez recevoir une réponse JSON de ce type :
Réponse
{
"kind": "sql#database",
"charset": "utf8",
"collation": "utf8_general_ci",
"etag": "etag",
"name": "sys",
"instance": "instance-id",
"selfLink": "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases/sys",
"project": "project-id"
}
Client psql
Pour obtenir des informations de référence, reportez-vous à la commande list (répertorier).
Lorsque vous répertoriez les bases de données à l'aide du client psql
, vous obtenez des bases de données de modÚles supplémentaires et une base de données systÚme qui ne sont pas affichées par la console. Vous ne pouvez pas supprimer ni gérer la base de données systÚme.
\l
Supprimer une base de données
Pour supprimer une base de données sur l'instance Cloud SQL :
Console
-
Dans la console Google Cloud , accédez à la page Instances Cloud SQL.
Accéder à la page Instances Cloud SQL
-
Pour ouvrir la page Présentation d'une instance, cliquez sur son nom.
- Cliquez sur Bases de données dans le menu de gauche.
- Dans la liste des bases de données, recherchez celle que vous souhaitez supprimer et cliquez sur l'icÎne de la corbeille.
- Dans la boßte de dialogue Supprimer la base de données, saisissez le nom de la base de données, puis cliquez sur Supprimer.
gcloud
Pour plus d'informations, consultez la page sur gcloud
sql databases delete
.
gcloud sql databases delete DATABASE_NAME \
--instance=INSTANCE_NAME
REST v1
La requĂȘte suivante exĂ©cute la mĂ©thode databases:delete pour supprimer la base de donnĂ©es spĂ©cifiĂ©e.
Avant d'utiliser les donnĂ©es de requĂȘte, effectuez les remplacements suivants :
- project-id : ID du projet
- instance-id : ID de l'instance.
- database-name : nom d'une base de données dans l'instance Cloud SQL.
Méthode HTTP et URL :
DELETE https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases/database-name
Pour envoyer votre requĂȘte, dĂ©veloppez l'une des options suivantes :
curl (Linux, macOS ou Cloud Shell)
Exécutez la commande suivante :
curl -X DELETE \
-H "Authorization: Bearer $(gcloud auth print-access-token)" \
"https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases/database-name"
PowerShell (Windows)
Exécutez la commande suivante :
$cred = gcloud auth print-access-token
$headers = @{ "Authorization" = "Bearer $cred" }
Invoke-WebRequest `
-Method DELETE `
-Headers $headers `
-Uri "https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases/database-name" | Select-Object -Expand Content
Vous devriez recevoir une réponse JSON de ce type :
Réponse
{
"kind": "sql#operation",
"targetLink": "https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id",
"status": "PENDING",
"user": "user@example.com",
"insertTime": "2020-01-21T22:43:37.981Z",
"operationType": "DELETE_DATABASE",
"name": "operation-id",
"targetId": "instance-id",
"selfLink": "https://sqladmin.googleapis.com/v1/projects/project-id/operations/operation-id",
"targetProject": "project-id"
}
REST v1beta4
La requĂȘte suivante exĂ©cute la mĂ©thode databases:delete pour supprimer la base de donnĂ©es spĂ©cifiĂ©e.
Avant d'utiliser les donnĂ©es de requĂȘte, effectuez les remplacements suivants :
- project-id : ID du projet
- instance-id : ID de l'instance.
- database-name : nom d'une base de données dans l'instance Cloud SQL.
Méthode HTTP et URL :
DELETE https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases/database-name
Pour envoyer votre requĂȘte, dĂ©veloppez l'une des options suivantes :
curl (Linux, macOS ou Cloud Shell)
Exécutez la commande suivante :
curl -X DELETE \
-H "Authorization: Bearer $(gcloud auth print-access-token)" \
"https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases/database-name"
PowerShell (Windows)
Exécutez la commande suivante :
$cred = gcloud auth print-access-token
$headers = @{ "Authorization" = "Bearer $cred" }
Invoke-WebRequest `
-Method DELETE `
-Headers $headers `
-Uri "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases/database-name" | Select-Object -Expand Content
Vous devriez recevoir une réponse JSON de ce type :
Réponse
{
"kind": "sql#operation",
"targetLink": "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id",
"status": "PENDING",
"user": "user@example.com",
"insertTime": "2020-01-21T22:43:37.981Z",
"operationType": "DELETE_DATABASE",
"name": "operation-id",
"targetId": "instance-id",
"selfLink": "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/operations/operation-id",
"targetProject": "project-id"
}
Client psql
Pour en savoir plus, consultez la section DROP DATABASE de la documentation PostgreSQL.
DROP DATABASE [database_name];
Ătapes suivantes
Faites l'essai
Si vous débutez sur Google Cloud, créez un compte pour évaluer les performances de Cloud SQL en conditions réelles. Les nouveaux clients bénéficient également de 300 $ de crédits gratuits pour exécuter, tester et déployer des charges de travail.
Profiter d'un essai gratuit de Cloud SQL
Sauf indication contraire, le contenu de cette page est régi par une licence Creative Commons Attribution 4.0, et les échantillons de code sont régis par une licence Apache 2.0. Pour en savoir plus, consultez les RÚgles du site Google Developers. Java est une marque déposée d'Oracle et/ou de ses sociétés affiliées.
DerniĂšre mise Ă jour le 2025/09/16 (UTC).
[[["Facile à comprendre","easyToUnderstand","thumb-up"],["J'ai pu résoudre mon problÚme","solvedMyProblem","thumb-up"],["Autre","otherUp","thumb-up"]],[["Difficile à comprendre","hardToUnderstand","thumb-down"],["Informations ou exemple de code incorrects","incorrectInformationOrSampleCode","thumb-down"],["Il n'y a pas l'information/les exemples dont j'ai besoin","missingTheInformationSamplesINeed","thumb-down"],["ProblÚme de traduction","translationIssue","thumb-down"],["Autre","otherDown","thumb-down"]],["DerniÚre mise à jour le 2025/09/16 (UTC)."],[],[],null,[]]