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