日韩性视频-久久久蜜桃-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命令行导入导出数据库的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 黄色在线免费看 | 亚洲国产精品福利 | 麻豆免费看片 | 六月激情综合网 | 中文人妻熟女乱又乱精品 | 国产精品探花视频 | 51av在线 | 93久久精品日日躁夜夜躁欧美 | 国产在线h| 爱爱视频天天干 | 自拍亚洲国产 | 欧美一区二区在线观看视频 | 51成人精品网站 | 免费观看成人鲁鲁鲁鲁鲁视频 | 亚洲一级一区 | 久久成人国产 | 日韩性视频 | www在线观看免费视频 | 亚洲深夜在线 | 日韩在线观看视频一区二区 | 日本护士做爰视频 | www五月| 91亚洲精品久久久蜜桃网站 | 少妇按摩一区二区三区 | 91精品国产综合久久久蜜臀粉嫩 | 操一操av | 日韩av在线播放不卡 | 亚洲剧情在线 | 天堂一区在线 | 日本少妇ⅹxxxxx视频 | 中文字幕在线视频第一页 | 欧美成人精精品一区二区频 | 日韩骚片| 亚洲专区欧美 | 四虎福利视频 | 91社区福利 | 国产男女裸体做爰爽爽 | 久久青青热 | gai免费观看网站外网 | 久久久久成人精品免费播放动漫 | 日韩国产欧美一区二区 | 亚洲成a人片在线www | 成人av免费在线观看 | 日韩人妻精品在线 | 日韩伦人妻无码 | 欧美日韩国产一区二区在线观看 | 都市激情亚洲 | 深爱激情综合网 | 国产精品免费无遮挡无码永久视频 | 色婷婷色婷婷 | 中日毛片| 蜜臀av色欲a片无码精品一区 | 日本一级大片 | 九色porny自拍视频在线播放 | 2019av视频| 欧日韩av| 男男做的视频 | 日韩视频免费看 | 国产欧美在线观看视频 | 精品婷婷 | 国产精品中文在线 | 爱情岛论坛成人 | 亚洲一区在线视频观看 | 精品人妻一区二区三区视频 | 日韩黄色网络 | 无码人妻一区二区三区线 | 三级男人添奶爽爽爽视频 | 人人搞人人爱 | 国产午夜福利精品 | 日本在线视频免费 | 日韩av毛片在线观看 | 在线观看网站黄 | 无码人妻精品一区二区三区不卡 | 98堂 最新网名| 婷婷激情小说网 | 徐锦江一级淫片免费看 | www日韩在线 | 美女xx00 | 国产免费又黄又爽又色毛 | 日穴| 精品国产一级片 | 菲律宾黄色片 | 国产女人18水真多18精品一级做 | 少妇在线播放 | 精品99久久久久成人网站免费 | 亚洲一区视频在线播放 | 午夜av在线播放 | 黄色肉肉视频 | 天堂资源最新在线 | 国产精品无码av在线有声小说 | 日本不卡1 | 亚洲一区日本 | av每日更新 | 东方伊甸园av在线 | 亚洲三级av | 操操操插插插 | 欧美日韩综合在线观看 | 女生扒开腿让男生操 | 九九九在线 |