Golang에서 데이터베이스 마이그레이션을 사용하면 데이터베이스가 코드와 동기화됩니다. Ent 또는 Gor migration과 같은 라이브러리를 사용하여 마이그레이션을 수행할 수 있습니다. Ent 사용: Ent 설치. 마이그레이션 파일을 생성합니다. 마이그레이션을 실행합니다. Gor migration 사용: Gor migration을 설치하십시오. 마이그레이션 파일을 생성합니다(상향 및 하향 마이그레이션 기능 포함). 마이그레이션을 실행합니다.
Golang에서 데이터베이스 마이그레이션을 어떻게 사용하나요?
데이터베이스 마이그레이션은 데이터베이스가 항상 코드와 동기화되도록 데이터베이스 스키마 변경 사항을 관리하는 기술입니다. Golang에서는 [ent](https://entgo.io/docs/ migration/) 또는 [gor migration](https://github.com/go-gor migration/gor migration)과 같은 라이브러리를 사용하여 데이터베이스 마이그레이션을 수행할 수 있습니다.
데이터베이스 마이그레이션에 Ent 사용
Ent는 내장 마이그레이션 시스템을 제공하는 Golang ORM입니다. 데이터베이스 마이그레이션에 Ent를 사용하려면 다음 단계를 따르세요.
Ent 설치:
go get github.com/ent/ent/cmd/ent
마이그레이션 파일 생성:
ent generate migration AddUser
마이그레이션 실행:
ent migrate
Gor migration을 데이터베이스 마이그레이션에 사용
고르마이그레이션 Golang에서 데이터베이스 마이그레이션을 수행하는 데 사용할 수 있는 타사 라이브러리입니다. Gor migration을 사용하려면 다음 단계를 따르십시오.
Gor migration 설치:
go get github.com/go-gormigrate/gormigrate/v2
마이그레이션 파일 생성:
touch migrations/001_add_user.go
마이그레이션 파일에 코드 작성:
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") }
마이그레이션 실행:
gormigrate -up
실용적 case
사용자 테이블이 있고 해당 테이블의 스키마가 변경되었다고 가정해 보겠습니다. Gor 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 Password string } return db.AutoMigrate(&User{}) } func Down(db *gorm.DB) error { return db.Migrator().DropColumn("users", "password") }
이 마이그레이션을 실행하면 "users" 테이블에 새로운 "password" 열이 추가됩니다.
위 내용은 Golang에서 데이터베이스 마이그레이션을 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!