> 백엔드 개발 > Golang > GORM 및 pgtype.JSONB를 사용하여 Postgres에서 문자열 조각을 JSONB로 어떻게 저장할 수 있습니까?

GORM 및 pgtype.JSONB를 사용하여 Postgres에서 문자열 조각을 JSONB로 어떻게 저장할 수 있습니까?

Susan Sarandon
풀어 주다: 2024-11-20 16:47:39
원래의
963명이 탐색했습니다.

How Can I Store a Slice of Strings as JSONB in Postgres Using GORM and pgtype.JSONB?

pgtype.JSONB를 사용하여 GORM 및 Postgres에서 문자열 조각을 JSONB로 저장

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿