L'utilisation de la migration de base de données dans Golang garantit que la base de données est synchronisée avec le code. La migration peut être effectuée à l'aide de bibliothèques telles que Ent ou Gormigrate : Utilisation d'Ent : Installer Ent. Générez des fichiers de migration. Exécutez la migration. Utilisation de Gormigrate : installez Gormigrate. Créez des fichiers de migration (y compris les fonctions de migration ascendante et descendante). Exécutez la migration.
Comment utiliser la migration de base de données dans Golang ?
La migration de base de données est une technique permettant de gérer les modifications du schéma de base de données afin de garantir que la base de données est toujours synchronisée avec le code. Dans Golang, les migrations de bases de données peuvent être effectuées à l'aide de bibliothèques telles que [ent](https://entgo.io/docs/migrate/) ou [gormigrate](https://github.com/go-gormigrate/gormigrate).
Utilisez Ent pour la migration de bases de données
Ent est un ORM Golang qui fournit un système de migration intégré. Pour utiliser Ent pour la migration de base de données, suivez ces étapes :
Installer Ent :
go get github.com/ent/ent/cmd/ent
Générer le fichier de migration :
ent generate migration AddUser
Exécuter la migration :
ent migrate
Utiliser Gormigrate pour la migration de base de données
Gormigrer est une bibliothèque tierce qui peut être utilisée pour effectuer des migrations de bases de données dans Golang. Pour utiliser Gormigrate, suivez ces étapes :
Installez Gormigrate :
go get github.com/go-gormigrate/gormigrate/v2
Créez le fichier de migration :
touch migrations/001_add_user.go
Écrivez le code dans le fichier de migration :
import ( "github.com/go-gormigrate/gormigrate/v2/gormigrate" "gorm.io/gorm" ) func Up(db *gorm.DB) error { type User struct { ID uint `gormigrate:"primary_key"` Name string } return db.AutoMigrate(&User{}) } func Down(db *gorm.DB) error { return db.Migrator().DropTable("users") }
Exécutez la migration :
gormigrate -up
Pratique cas
Supposons que nous ayons une table utilisateur et que son schéma ait changé. En utilisant Gormigrate, nous pouvons créer un fichier de migration comme celui-ci :
import ( "github.com/go-gormigrate/gormigrate/v2/gormigrate" "gorm.io/gorm" ) func Up(db *gorm.DB) error { type User struct { ID uint `gormigrate:"primary_key"` Name string Password string } return db.AutoMigrate(&User{}) } func Down(db *gorm.DB) error { return db.Migrator().DropColumn("users", "password") }
L'exécution de cette migration ajoutera une nouvelle colonne "mot de passe" au tableau "utilisateurs".
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!