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 문으로 변환됩니다.
이전 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 구별
두 방법 모두 비슷한 목적을 제공하지만 동작은 다릅니다.
위 내용은 GORM의 Upsert 기능은 FirstOrCreate 및 FirstOrInit과 비교하여 어떻게 작동합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!