>백엔드 개발 >Golang >Go에서 레코드 존재 여부를 효율적으로 확인하고 레코드가 없는 경우 삽입하는 방법은 무엇입니까?

Go에서 레코드 존재 여부를 효율적으로 확인하고 레코드가 없는 경우 삽입하는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-12 15:27:13680검색

How to Efficiently Check for Record Existence and Insert if Absent in Go?

Go에 레코드 존재 확인 및 없는 경우 삽입

제공된 Go 코드에서 사용자 합계를 검색하는 쿼리가 실행됩니다. '건설' 카테고리에 대한 카테고리, 하위 카테고리 및 산업 테이블에서 계산됩니다. 그러나 코드는 쿼리를 실행하기 전에 레코드가 존재하는지 여부를 확인하지 않습니다.

레코드가 있는지 확인하고, 없으면 삽입하려면 다음과 같은 방법을 사용할 수 있습니다.

package main

import (
    "database/sql"
    "fmt"
    "os"

    "github.com/gin-gonic/gin"
)

func main() {
    router := gin.New()
    router.Use(gin.Logger())
    router.Use(gin.Recovery())
    dbUser := os.Getenv("DB_USER")
    dbPwd := os.Getenv("DB_PASSWORD")
    dbHost := os.Getenv("DB_HOST")
    dbPort := os.Getenv("DB_PORT")
    dbDatabase := os.Getenv("DB_NAME")
    db, err := sql.Open("mysql", fmt.Sprintf("%s:%s@tcp(%s:%s)/%s", dbUser, dbPwd, dbHost, dbPort, dbDatabase))
    if err != nil {
        fmt.Print(err.Error())
    }
    err = db.Ping()
    if err != nil {
        fmt.Print(err.Error())
    }

    var exists bool
    query := "SELECT EXISTS(SELECT 1 FROM ...)"
    row := db.QueryRow(query)
    if err = row.Scan(&exists); err != nil {
        return err
    }

    if !exists {
        query = "INSERT ...";
        if _, err = db.Exec(query); err != nil {
            return err
        }
    }
}

이 코드는 쿼리를 실행하고 그 결과를 존재 변수에 저장하여 레코드가 존재하는지 확인합니다. 레코드가 존재하지 않으면 다른 쿼리를 실행하여 데이터베이스에 레코드를 삽입합니다.

위 내용은 Go에서 레코드 존재 여부를 효율적으로 확인하고 레코드가 없는 경우 삽입하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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