首頁 > 後端開發 > Golang > Go中如何有效率地檢查記錄是否存在,不存在則插入?

Go中如何有效率地檢查記錄是否存在,不存在則插入?

DDD
發布: 2024-12-12 15:27:13
原創
679 人瀏覽過

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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板