mysql go命令行_Go语言调用mysql.exe和mysqldump命令行导入导出数据库
最近準備將我平時寫的ruby和python小工具推廣到整個小組,以提高小組工作效率。但是效果不太理想,主要是腳本語言依賴環境,安裝配置比較繁瑣,組員們雖然很羨慕我的工具,但是愿意嘗試很少。
Go語言最近比較火,了解了下發現它編譯后生成exe,沒有依賴,發給其他人就可以直接用,于是我又萌生了將部分通用工具用Go改寫的念頭。
第一個改寫的工具很簡單,就是將遠程的數據庫數據導出到本地并導入到本地的數據庫。在ruby 中代碼中主要的邏輯是以下兩行代碼
`mysqldump -h#{host} -u#{user} -p#{pass} #{db} --complete-insert --skip-comments --compact --add-drop-table >sqls/#{websitename}.sql`
`mysql --reconnect --default-character-set=utf8 -h #{exporthost} -u#{exportuser} -p#{exportpass} --database=#{exportdb} < #{file}`
就是這么簡單的兩行命令行代碼在Go開發中,卻碰了壁,網上搜索一番也沒有直接的回答,在網上仔細研究了相關論壇回帖的只字片語和本人的不斷嘗試,終于解決了這個問題。
Go相關代碼如下:
mysqldump:
func exportDB(info WebInfo,webname string) error{
argv := []string{"--complete-insert","--skip-comments","--compact","--add-drop-table","-h"+info.Mysqlhost,"-u"+info.Mysqluname,"-p"+info.Mysqlupasswd,info.Mysqldb}
cmd := exec.Command("mysqldump", argv...)
f,err:=os.OpenFile("sqls/"+webname+".sql",os.O_CREATE|os.O_RDWR,os.ModePerm|os.ModeTemporary)
if(err!=nil){
fmt.Println("打開sql文件失敗")
return err
}
defer f.Close()
cmd.Stdout=f
cmd.Stderr=os.Stderr
cmd.Start()
cmd.Run()
cmd.Wait()
return nil
}
mysql:
func importToLocal(info Info) error{
argv := []string{"--reconnect","--default-character-set=utf8","-h"+info.Mysqlhost,"-u"+info.Mysqluname,"-p"+info.Mysqlupasswd,"--database="+info.Mysqldb}
cmd := exec.Command("mysql", argv...)
f,err:=os.Open("sqls/"+info.Webname+".sql")
if(err!=nil){
fmt.Println("讀取sql文件失敗")
return err
}
defer f.Close()
cmd.Stdin=f
cmd.Stdout=os.Stdout
cmd.Stderr=os.Stderr
cmd.Start()
cmd.Run()
cmd.Wait()
return nil
}
上面兩段代碼,是我整個工具代碼中的一部分,無法直接復制使用,要使用的話,首先要導入os/exec等package,然后將函數中部分變量替換成自己的數據庫信息。
import (
"fmt"
"os"
"os/exec"
)
type Info struct {
Webname string
Mysqlhost string
Mysqldb string
Mysqluname string
Mysqlupasswd string
}
type WebInfo Info
下面說說Go中調用命令行的一些迷惑地方。
1. exec.Command 里調用命令行,必須將命令行參數拆分成數組,放入函數的參數中。這個相對而言比較容易察覺。
2. exec.Command 不支持命令行中的 < 和 > 重定向操作,如果要實現類似的功能,可以在代碼里打開文件,并將文件描述符f賦值給?cmd.Stdin或者cmd.Stdout。這個問題很隱蔽,是調用命令行中很讓人困惑的地方。
最后說說新學Go語言的感受,相對于php、ruby、python寫起來還是很繁瑣的。不過作為一個靜態編譯類型的語言,Go語言還是挺好入門的。編譯速度很快。安裝vscode插件后可以在編寫代碼同時驗證代碼語法,代碼提示也很全,開發起來很方便。總體而言,開發效率挺高的。
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的mysql go命令行_Go语言调用mysql.exe和mysqldump命令行导入导出数据库的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: suse linux mysql下载_S
- 下一篇: mysql grant 语法格式_MyS