>  기사  >  백엔드 개발  >  GORM의 Upsert 기능은 FirstOrCreate 및 FirstOrInit과 비교하여 어떻게 작동합니까?

GORM의 Upsert 기능은 FirstOrCreate 및 FirstOrInit과 비교하여 어떻게 작동합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-10 00:52:02639검색

How Does GORM's Upsert Feature Work Compared to FirstOrCreate and FirstOrInit?

Upsert: GORM에서 생성 또는 업데이트

GORM에서는 FirstOrCreate 및 FirstOrInit 메소드를 모두 사용하여 데이터베이스 레코드를 검색하거나 생성할 수 있습니다. 그러나 레코드가 새로 생성되었는지 또는 업데이트되었는지 확인하는 것이 불분명할 수 있습니다.

Upsert-On-Contribute가 포함된 Upsert 솔루션

GORM 1.20.x부터 향상된 다양한 데이터베이스에 대한 충돌 처리 기능을 활용하는 Upsert 기능이 도입되었습니다.

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

이것은 스니펫은 다음과 같은 SQL 문으로 변환됩니다.

  • SQL Server: MERGE INTO "users" USING *** WHEN NOT MATCHED THEN INSERT *** WHEN MATCHED THEN UPDATE SET "name"="excluded"."name";
  • PostgreSQL: INSERT INTO "users" *** ON CONFLICT ("id") DO UPDATE SET "name"="excluded "."이름", "age"="제외됨"."age";
  • MySQL: INSERT INTO 'users' *** ON DUPLICATE KEY UPDATE 'name'=VALUES(name),'age=VALUES(age);

이전 GORM 버전에 대한 대체 솔루션

1.9.x 이전 GORM 버전의 경우 더 효율적인 접근 방식은 먼저 업데이트를 시도한 다음 업데이트를 시도하는 것입니다. 일치하는 항목이 없으면 새 레코드를 생성합니다.

// Update only set name=nick
if err := db.Model(&newUser).Where("id = ?", 3333).Update("name", "nick").Error; err != nil {
  // Handle error...
  if gorm.IsRecordNotFoundError(err) {
    db.Create(&newUser)  // Create new record from newUser
  }
}

FirstOrInit과 FirstOrCreate 구별

두 방법 모두 비슷한 목적을 제공하지만 동작은 다릅니다.

  • FirstOrInit: 레코드가 존재하지 않는 경우 구조체를 초기화하지만 레코드가 존재하지 않습니다. 레코드를 생성합니다.
  • FirstOrCreate: 레코드가 없으면 생성하고 해당 레코드를 구조체로 검색합니다.

위 내용은 GORM의 Upsert 기능은 FirstOrCreate 및 FirstOrInit과 비교하여 어떻게 작동합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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