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