Fetch the repository succeeded.
//++++++++++++++++++++++++++++++++++++++++
// 《Go语言高级开发与实战》源码
//++++++++++++++++++++++++++++++++++++++++
// Author:廖显东(ShirDon)
// Blog:https://www.shirdon.com/
// 公众号:源码大数据
// 仓库地址:https://gitee.com/shirdonl/goAdvanced
// 仓库地址:https://github.com/shirdonl/goAdvanced
//++++++++++++++++++++++++++++++++++++++++
package main
// 从Mysql中导出数据到CSV文件
import (
"database/sql"
"encoding/csv"
"fmt"
_ "github.com/go-sql-driver/mysql"
"os"
)
var (
tables = []string{"user", "order"}
count = len(tables)
ch = make(chan bool, count)
)
func main() {
//连接数据库
db, err := sql.Open("mysql", "root:a123456@tcp(127.0.0.1:3306)/chapter1?charset=utf8")
defer db.Close()
if err != nil {
panic(err.Error())
}
for _, table := range tables {
go SqlQuery(db, table, ch)
}
for i := 0; i < count; i++ {
<-ch
}
fmt.Println("完成!")
}
//运行SQL
func SqlQuery(db *sql.DB, table string, ch chan bool) {
fmt.Println("开始处理:", table)
rows, _ := db.Query(fmt.Sprintf("SELECT * from %s", table))
columns, err := rows.Columns()
if err != nil {
panic(err.Error())
}
values := make([]sql.RawBytes, len(columns))
scanArgs := make([]interface{}, len(values))
for i := range values {
scanArgs[i] = &values[i]
}
totalValues := [][]string{}
for rows.Next() {
var s []string
//把每行的内容添加到scanArgs,也添加到了values
err = rows.Scan(scanArgs...)
if err != nil {
panic(err.Error())
}
for _, v := range values {
s = append(s, string(v))
}
totalValues = append(totalValues, s)
}
if err = rows.Err(); err != nil {
panic(err.Error())
}
exportToCSV(table+".csv", columns, totalValues)
ch <- true
}
//导出到CSV
func exportToCSV(file string, columns []string, totalValues [][]string) {
f, err := os.Create(file)
if err != nil {
panic(err)
}
f.WriteString("\xEF\xBB\xBF")
defer f.Close()
w := csv.NewWriter(f)
for a, i := range totalValues {
if a == 0 {
w.Write(columns)
w.Write(i)
} else {
// fmt.Println(i)
w.Write(i)
}
}
w.Flush()
fmt.Println("处理完毕:", file)
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。