GORM 사용자는 문자열 조각을 JSONB로 저장하려고 할 때 문제에 직면할 수 있습니다. GORM 특정 유형(postgres.Jsonb)에 의존하지 않고 Postgres의 객체입니다. 이 기사에서는 이러한 어려움을 극복하기 위해 pgtype.JSONB를 활용하는 솔루션에 대해 자세히 설명합니다.
pgx와 함께 GORM을 활용하는 경우 pgtype 패키지를 활용하여 JSONB 데이터 유형을 나타낼 수 있습니다. 이 패키지는 Go 구조체에서 JSONB 필드를 관리하기 위한 편리한 솔루션을 제공하는 pgtype.JSONB 유형을 제공합니다.
이 방법을 구현하려면 다음과 같이 구조체를 정의하기만 하면 됩니다.
// User represents a GORM model type User struct { gorm.Model Data pgtype.JSONB `gorm:"type:jsonb;default:'[]';not null"` }
이 예에서 데이터 필드는 pgtype.JSONB로 정의됩니다.
JSONB에 액세스 값
데이터베이스에서 데이터 필드의 값을 검색하려면 AssignTo 메서드를 사용할 수 있습니다.
u := User{} db.Find(&u) var data []string err := u.Data.AssignTo(&data) if err != nil { log.Fatal(err) }
JSONB 값 설정
데이터베이스의 데이터 필드를 업데이트하려면 Set 방법:
u := User{} err := u.Data.Set([]string{"abc", "def"}) if err != nil { return } db.Updates(&u)
이 접근 방식은 기본 드라이버의 기능을 활용하여 사용자 정의 코드가 필요하지 않으며 []문자열뿐만 아니라 모든 JSONB 유형을 원활하게 처리할 수 있습니다.
위 내용은 GORM 및 pgtype.JSONB를 사용하여 Postgres에서 문자열 조각을 JSONB로 어떻게 저장할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!