>백엔드 개발 >Golang >GORM 2.0에서 마지막으로 삽입된 ID를 검색하는 방법은 무엇입니까?

GORM 2.0에서 마지막으로 삽입된 ID를 검색하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-25 11:55:021133검색

How to Retrieve the Last Inserted ID in GORM 2.0?

GORM 2.0의 마지막 삽입 ID

GORM 2.0에서는 데이터베이스 삽입 실행 후 마지막으로 삽입된 ID를 구하는 방식이 이전과 변경되었습니다. 버전. 이 기사에서는 현재 버전의 GORM을 사용하여 마지막으로 삽입된 ID를 검색하는 방법을 살펴봅니다.

GORM v2.0에서 Begin() 함수는 이전에 LastInsertId( ) 방법. 대신 데이터베이스에 행을 삽입한 후 Last() 함수를 사용해야 합니다. 또는 보다 효율적인 접근 방식을 사용할 수 있습니다.

Create 함수를 사용하여 데이터베이스를 성공적으로 삽입한 후 GORM은 함수에 전달된 모델의 ID를 자동으로 채웁니다. 따라서 모델에 마지막으로 삽입된 ID가 이미 포함되어 있으므로 db.Last(&model)를 호출할 필요가 없습니다. 이 기술은 불필요한 데이터베이스 호출을 방지할 뿐만 아니라 데이터 무결성도 보장합니다.

이를 입증하려면 다음 예를 고려하십시오.

<code class="go">type User struct {
    gorm.Model
    Name string
}

user1 := User{Name: "User One"}

_ = db.Transaction(func(tx *gorm.DB) error {
    tx.Create(&user1)
    return nil
})

// This is unnecessary
// db.Last(&user1)

fmt.Printf("User one ID: %d\n", user1.ID)</code>

이 예에서 user1 모델은 마지막으로 삽입된 항목을 자동으로 포함합니다. user1.ID를 사용하여 직접 접근할 수 있는 Create 함수를 실행한 후의 ID입니다. 이 방법은 효율적이며 추가 데이터베이스 쿼리나 불필요한 함수 호출이 필요하지 않습니다.

위 내용은 GORM 2.0에서 마지막으로 삽입된 ID를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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