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ù)庫連接設置
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腳本,但可能無法處理更復雜的情況,比如含有分號的SQL字符串或存儲過程。對于更復雜的情況,您可能需要更精細的解析方法或直接在數(shù)據(jù)庫管理工具中執(zhí)行復雜腳本。
總結
到此這篇關于GoLang中sql.Exec()報錯解決辦法的文章就介紹到這了,更多相關GoLang sql.Exec()報錯內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Golang實現(xiàn)自定義時間結構體并支持Json&Gorm
因為時區(qū)等問題,很多項目需要自定義時區(qū)和時間格式,所以這篇文章主要為大家介紹了Golang如何實現(xiàn)自定義時間結構體并支持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-12
golang之數(shù)據(jù)驗證validator的實現(xiàn)
這篇文章主要介紹了golang之數(shù)據(jù)驗證validator的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10
Go框架三件套Gorm?Kitex?Hertz基本用法與常見API講解
這篇文章主要為大家介紹了Go框架三件套Gorm?Kitex?Hertz的基本用法與常見API講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪<BR>2023-02-02

