登录
首页 >  Golang >  Go问答

如何使用 exec.Command 在 golang 中执行 Mysql 脚本

来源:Golang技术栈

时间:2023-03-21 13:29:47 348浏览 收藏

目前golang学习网上已经有很多关于Golang的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《如何使用 exec.Command 在 golang 中执行 Mysql 脚本》,也希望能帮助到大家,如果阅读完后真的对你学习Golang有帮助,欢迎动动手指,评论留言并分享~

问题内容

您好我正在尝试执行脚本以使用 Golang 将数据填充到数据库中

func executeTestScript(){
    cmd := exec.Command("/usr/local/mysql/bin/mysql", "-h127.0.0.1", "-P3333", "-uusr", "-pPassxxx", "-Ddtb_test",  "

问题是我收到错误:

ERROR 1049 (42000): Unknown database '

我认为问题是 exec 认为是 dbname 的最后一个参数(sql 脚本路径)

终端中的以下命令正在运行:

/usr/local/mysql/bin/mysql --host=127.0.0.1 --port=3333 --user=usr --password=Passxxx --database=dtb_test 

但我尝试在 Go 中复制以自动执行脚本。

该脚本具有删除表、创建表、插入和带​​有 FK 关系的 PK,这是一个非常完整的脚本,因此我无法逐行执行,因此我决定执行 de mysql 程序将数据插入数据库中。

有什么建议?

正确答案

+1 来自@MatteoRagni 的回答,展示了如何在 Golang 中进行标准输入重定向。

但这是我使用的一个简单的替代方案:

cmd := exec.Command("/usr/local/mysql/bin/mysql", "-h127.0.0.1", "-P3333", 
  "-uusr", "-pPassxxx", "-Ddtb_test",
  "-e", "source /Users/XXX/Documents/test/scripts/olds/SCRIPT_XXX.sql")

您不必让 mysql 客户端使用标准输入重定向读取脚本。相反,您可以让 mysql 客户端执行特定命令,即source .

PS:我也不会在您的代码中输入主机、端口、用户和密码。这意味着每次更改这些连接参数时都必须重新编译程序。此外,在命令行上以明文形式使用密码也不安全。相反,我会将所有连接参数放入默认文件并使用mysql --defaults-file=FILENAME.

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表