golang问下 是否不支持sql多条一起执行的呢

hellsam · 2018-04-12 02:24:47 · 5102 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2018-04-12 02:24:47 的主题,其中的信息可能已经有所发展或是发生改变。

如简单的2句放字符串然后执行就错误
 sql_2 := "insert into user_list (a,b)values('a','b');insert into user_list (c,d)values('c','d')"

这样拼接了2句 执行就错误
用的包是
github.com/go-sql-driver/mysql

不知道大家遇到过没  对于很多SQL语句来说 不支持多条拼接,需要分开一句句执行特别麻烦

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

5102 次点击  
加入收藏 微博
7 回复  |  直到 2020-01-07 13:22:18
buscoop
buscoop · #1 · 7年之前

you can use:

insert into user_list(a,b) values('a','b'),('c','d')

_admin_
_admin_ · #2 · 7年之前
hellsam
hellsam · #3 · 7年之前
buscoopbuscoop #1 回复

you can use: insert into user_list(a,b) values('a','b'),('c','d')

如果是 不同表呢 不同参数呢 如何解决呢

hellsam
hellsam · #4 · 7年之前
_admin__admin_ #2 回复

推荐你使用https://github.com/jmoiron/sqlx

这个暂时不用了。已经写很多了 不想返工了

jarlyyn
jarlyyn · #5 · 7年之前
hellsamhellsam #4 回复

#2楼 @_admin_ 这个暂时不用了。已经写很多了 不想返工了

sqlx兼容sql库的。

theSmallwhiteMe
theSmallwhiteMe · #6 · 5年之前

遇到同样问题; 批量更新时拼接sql提示语法错误 此博文解决了疑惑

mysql 一些驱动默认是不支持multi statements的需要进行配置,因为 multi statements 可能会增加sql注入的风险 需要加入参数 multiStatements=true https://blog.csdn.net/raogeeg/article/details/94452405

guaik
guaik · #7 · 5年之前
func (obj *XXXX) DeleteXXXX(xxxID int64) (err error) {
    tx, err := obj.db.Client.Begin()
    if err != nil {
        return
    }
    // -- 定义执行sql语句
    delXXX, err := tx.Prepare(`delete from XXX where xxxId=$1;`)
    if err != nil {
        return err
    }
    defer delXXX.Close()
    // 删除评论
    delYYY, err := tx.Prepare(`delete from YYY where xxxId=$1;`)
    if err != nil {
        return err
    }
    defer delYYY.Close()
    // -- 执行事务处理
    if _, err := delXXX.Exec(xxxID); err != nil {
        tx.Rollback()
        return err
    }
    if _, err := delYYY.Exec(xxxID); err != nil {
        tx.Rollback()
        return err
    }
    err = tx.Commit()
    return
}
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传