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

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

func executeTestScript(){

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

var out, stderr bytes.Buffer

cmd.Stdout = &out

cmd.Stderr = &stderr

err := cmd.Run()

if err != nil {

fmt.Println(fmt.Sprintf("Error executing query. Command Output: %+v\n: %+v, %v", out.String(), stderr.String(), err))

log.Fatalf("Error executing query. Command Output: %+v\n: %+v, %v", out.String(), stderr.String(), err)

}

}

问题是我遇到了错误:

ERROR 1049 (42000): Unknown database '< /Users/XXX/Documents/test/scripts/olds/SCRIPT_XXX.sql'

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

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

/usr/local/mysql/bin/mysql --host=127.0.0.1 --port=3333 --user=usr --password=Passxxx --database=dtb_test < /Users/XXX/Documents/roseula/scripts/olds/SCRIPT_XXX.sql

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

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

有什么建议?

引用\[1\]和\[2\]提供了两个关于在Golang使用exec.Command函数执行外部命令的示例代码。 在Golangexec.Command函数用于创建一个Cmd结构体,该结构体表示要执行的外部命令。可以通过设置Cmd的属性来指定命令的输入、输出和错误流。然后,可以使用Cmd的Start方法来启动命令的执行,并使用Wait方法等待命令执行完成。 在引用\[1\]的示例exec.Command函数用于执行Windows命令行(cmd.exe)。通过设置Cmd的Stdin属性,可以将输入绑定到一个缓冲区,然后可以向缓冲区写入命令。通过设置Cmd的Stdout属性,可以将输出绑定到一个缓冲区,以便获取命令的输出结果。 在引用\[2\]的示例exec.Command函数用于执行OpenSSL命令。通过设置Cmd的Stdin、Stdout和Stderr属性,可以分别绑定输入、输出和错误流。通过调用Cmd的Start方法启动命令的执行,并使用管道读取命令的输出和错误信息。 总结来说,通过使用exec.Command函数,可以在Golang执行外部命令,并获取其输出和错误信息。可以通过设置Cmd的属性来指定命令的输入、输出和错误流。然后,可以使用Cmd的Start方法启动命令的执行,并使用Wait方法等待命令执行完成。 #### 引用[.reference_title] - *1* [golang执行命令 exec.Command](https://blog.csdn.net/a19352226/article/details/53747323)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [golang exec.Command执行cmd,jar包自定义输入与输出](https://blog.csdn.net/yoorxee/article/details/123323716)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值