GoLang中sql.Exec()報錯解決辦法
【報錯內(nèi)容】
Sorry, can not exec into mysql: Error 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ...
【原因】
sql.Exec
在大多數(shù)情況下只能執(zhí)行單條SQL語句。如果您的SQL腳本包含多條語句,您需要將它們分割并逐一執(zhí)行。這通常涉及將整個SQL腳本內(nèi)容按照語句分隔符(通常是分號 ;
)分割成單獨的語句,然后逐個執(zhí)行。
如果需要執(zhí)行兩條MySQL語句,一定要分開來執(zhí)行sql.Exec(),這里使用split函數(shù)來進行語句拆分。
如下:
package main import ( "database/sql" "fmt" "log" "strings" _ "github.com/go-sql-driver/mysql" ) func main() { // 數(shù)據(jù)庫連接設(shè)置 dsn := "username:password@tcp(host:port)/dbname" db, err := sql.Open("mysql", dsn) if err != nil { log.Fatal(err) } defer db.Close() // 測試數(shù)據(jù)庫連接 if err = db.Ping(); err != nil { log.Fatal(err) } // SQL命令 sqlCommands := ` DROP TABLE IF EXISTS combinedData; CREATE TABLE combinedData( ProducerName VARCHAR(255) ); ` // 按分號分割命令 commands := strings.Split(sqlCommands, ";") for _, cmd := range commands { // 去除字符串首尾的空白字符 cmd = strings.TrimSpace(cmd) if cmd != "" { // 執(zhí)行SQL命令 _, err = db.Exec(cmd) if err != nil { log.Fatal("執(zhí)行SQL出錯: ", err) } } } fmt.Println("所有SQL命令執(zhí)行完成") }
這段代碼將按照分號將SQL命令分割成單獨的語句,并逐一執(zhí)行它們。請注意,這種方法適用于簡單的SQL腳本,但可能無法處理更復(fù)雜的情況,比如含有分號的SQL字符串或存儲過程。對于更復(fù)雜的情況,您可能需要更精細的解析方法或直接在數(shù)據(jù)庫管理工具中執(zhí)行復(fù)雜腳本。
總結(jié)
到此這篇關(guān)于GoLang中sql.Exec()報錯解決辦法的文章就介紹到這了,更多相關(guān)GoLang sql.Exec()報錯內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Golang實現(xiàn)自定義時間結(jié)構(gòu)體并支持Json&Gorm
因為時區(qū)等問題,很多項目需要自定義時區(qū)和時間格式,所以這篇文章主要為大家介紹了Golang如何實現(xiàn)自定義時間結(jié)構(gòu)體并支持Json&Gorm,希望對大家有所幫助2024-03-03以go為例探究beyla從環(huán)境變量BEYLA_OPEN_PORT發(fā)現(xiàn)進程原理
這篇文章主要為大家介紹了以golang進程為例,研究beyla從環(huán)境變量BEYLA_OPEN_PORT(即通過端口)發(fā)現(xiàn)進程的原理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-12-12Go事務(wù)中止時是否真的結(jié)束事務(wù)解析
這篇文章主要為大家介紹了Go事務(wù)中止時是否真的結(jié)束事務(wù)實例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04golang之數(shù)據(jù)驗證validator的實現(xiàn)
這篇文章主要介紹了golang之數(shù)據(jù)驗證validator的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10Go框架三件套Gorm?Kitex?Hertz基本用法與常見API講解
這篇文章主要為大家介紹了Go框架三件套Gorm?Kitex?Hertz的基本用法與常見API講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪<BR>2023-02-02