GoLang:sql.Exec()报错

【报错内容】

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 在大多数情况下只能执行单条SQL语句。如果您的SQL脚本包含多条语句,您需要将它们分割并逐一执行。这通常涉及将整个SQL脚本内容按照语句分隔符(通常是分号 ;)分割成单独的语句,然后逐个执行。

如果需要执行两条MySQL语句,一定要分开来执行sql.Exec(),这里使用split函数来进行语句拆分。

如下:

Go 复制代码
package main

import (
    "database/sql"
    "fmt"
    "log"
    "strings"

    _ "github.com/go-sql-driver/mysql"
)

func main() {
    // 数据库连接设置
    dsn := "username:password@tcp(host:port)/dbname"
    db, err := sql.Open("mysql", dsn)
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

    // 测试数据库连接
    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 != "" {
            // 执行SQL命令
            _, err = db.Exec(cmd)
            if err != nil {
                log.Fatal("执行SQL出错: ", err)
            }
        }
    }

    fmt.Println("所有SQL命令执行完成")
}

这段代码将按照分号将SQL命令分割成单独的语句,并逐一执行它们。请注意,这种方法适用于简单的SQL脚本,但可能无法处理更复杂的情况,比如含有分号的SQL字符串或存储过程。对于更复杂的情况,您可能需要更精细的解析方法或直接在数据库管理工具中执行复杂脚本。

相关推荐
马优晨1 分钟前
数据库的连接池、最大连接池会话数目、SQL查询超时时间、连接等待超时时间是什么意思?
数据库·数据连接池·最大连接池会话数目·sql查询超时·连接等待超时
2301_769340677 分钟前
SQL如何处理分组后的空值统计_善用COALESCE与聚合函数
jvm·数据库·python
2301_7820404510 分钟前
在 Go 语言中声明包级(全局)映射的正确方法
jvm·数据库·python
zh15702311 分钟前
如何在 macOS 中使用 launchd 每分钟执行一次 PHP 脚本
jvm·数据库·python
阿正呀11 分钟前
HTML怎么显示计量值_HTML meter标签应用场景【指南】
jvm·数据库·python
qq_4138474015 分钟前
如何脱机维护表空间数据文件_OFFLINE与ONLINE状态的切换场景
jvm·数据库·python
jieyucx15 分钟前
Go 语言函数入门:定义、参数、返回值
c++·算法·golang·入门·函数
OpenClawCSDN16 分钟前
2026年腾讯云如何安装和集成Hermes Agent/OpenClaw?深度剖析
数据库·阿里云·云计算·腾讯云·京东云
XMYX-018 分钟前
20 - Go 互斥锁:Mutex 与并发安全
开发语言·golang
鸽芷咕18 分钟前
Oracle迁移到KingbaseES实战:语法差异、函数映射与避坑指南
数据库·oracle