>백엔드 개발 >Golang >FirstOrCreate 대 Upsert: 레코드를 생성하거나 업데이트하는 데 어떤 GORM 방법을 사용해야 합니까?

FirstOrCreate 대 Upsert: 레코드를 생성하거나 업데이트하는 데 어떤 GORM 방법을 사용해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-09 16:20:02451검색

FirstOrCreate vs. Upsert: Which GORM method should you use for creating or updating records?

GORM을 사용하여 레코드 생성 또는 업데이트: FirstOrCreate 및 Upsert

GORM은 레코드를 생성하거나 업데이트하는 두 가지 방법인 FirstOrCreate 및 FirstOrInit를 제공합니다. 그러나 실제로 이러한 방법을 사용하여 레코드가 생성되었는지 확인하는 것은 어려울 수 있습니다.

GORM 1.20.x 이상에서 Upsert 지원

버전 1.20.x부터 , GORM은 OnConflect 절을 통해 호환되는 Upsert 지원을 도입합니다. 이를 통해 다양한 데이터베이스에 레코드를 삽입할 수 있습니다.

// Update columns on conflict
DB.Clauses(clause.OnConflict{
  Columns:   []clause.Column{{Name: "id"}},
  DoUpdates: clause.AssignmentColumns([]string{"name", "age"}),
}).Create(&users)

GORM 1.9.x 이하 버전에 대한 대체 접근 방식

이전 버전의 GORM에서는 효율적인 방법으로 또는 레코드 업데이트는 먼저 업데이트를 시도한 후 레코드가 존재하지 않는 경우 삽입하는 것입니다.

if err := db.Model(&newUser).Where("id = ?", 3333).Update("name", "nick").Error; err != nil {
  if gorm.IsRecordNotFoundError(err) {
    db.Create(&newUser)
  }
}

FirstOrInit과 FirstOrCreate의 구별

다음이 중요합니다. FirstOrInit과 FirstOrCreate의 차이점에 유의하세요. 두 메서드 모두 기존 레코드나 새로 생성된 레코드에 대한 포인터를 반환하는 반면 FirstOrInit은 레코드를 생성하지 않고 구조체만 초기화하는 반면 FirstOrCreate는 레코드를 생성하여 구조체에 쿼리합니다.

위 내용은 FirstOrCreate 대 Upsert: 레코드를 생성하거나 업데이트하는 데 어떤 GORM 방법을 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.