日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql go命令行_Go语言调用mysql.exe和mysqldump命令行导入导出数据库

發布時間:2025/3/20 数据库 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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插件后可以在編寫代碼同時驗證代碼語法,代碼提示也很全,開發起來很方便??傮w而言,開發效率挺高的。

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的mysql go命令行_Go语言调用mysql.exe和mysqldump命令行导入导出数据库的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。