前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysql数据导出golang实现

mysql数据导出golang实现

作者头像
我的小碗汤
发布2018-09-30 10:32:10
3.4K0
发布2018-09-30 10:32:10
举报
文章被收录于专栏:我的小碗汤

Simple install the package to your $GOPATH with the go tool from shell:

代码语言:javascript
复制
$ go get -u github.com/go-sql-driver/mysql

具体说明请看:

库地址:

https://github.com/go-sql-driver/mysql

wiki说明:

https://github.com/go-sql-driver/mysql/wiki/Examples

代码示例如下,用到了go的flag包的能力,传入命令行参数。具体看helpInfo:

flag包的使用可以参考:golang flag包使用笔记

代码语言:javascript
复制
Usage of mysqldataexport:
  -port int
        the port for mysql,default:32085
  -addr string
        the address for mysql,default:10.146.145.67
  -user string
        the username for login mysql,default:dbuser

  -pwd  string
        the password for login mysql by the username,default:Admin@123
  -db   string
        the port for me to listen on,default:auditlogdb
  -tables string
        the tables will export data, multi tables separator by comma, default:op_log,sc_log,sys_log

代码:

代码语言:javascript
复制
package main

// 从Mysql中导出数据到CSV文件。

import (
    "database/sql"
    "encoding/csv"
    "fmt"
    "os"
    _ "github.com/go-sql-driver/mysql"
    "flag"
    "strings"
)

var (
    tables         = make([]string, 0)
    dataSourceName = ""
)

const (
    driverNameMysql = "mysql"

    helpInfo = `Usage of mysqldataexport:
  -port int
        the port for mysql,default:32085
  -addr string
        the address for mysql,default:10.146.145.67
  -user string
        the username for login mysql,default:dbuser

  -pwd  string
        the password for login mysql by the username,default:Admin@123
  -db   string
        the port for me to listen on,default:auditlogdb
  -tables string
        the tables will export data, multi tables separator by comma, default:op_log,sc_log,sys_log
    `
)

func init() {

    port := flag.Int("port", 32085, "the port for mysql,default:32085")
    addr := flag.String("addr", "10.146.145.67", "the address for mysql,default:10.146.145.67")
    user := flag.String("user", "dbuser", "the username for login mysql,default:dbuser")
    pwd := flag.String("pwd", "Admin@123", "the password for login mysql by the username,default:Admin@123")
    db := flag.String("db", "auditlogdb", "the port for me to listen on,default:auditlogdb")
    tabs := flag.String("tables", "op_log,sc_log,sys_log", "the tables will export data, multi tables separator by comma, default:op_log,sc_log,sys_log")

    flag.Usage = usage

    flag.Parse()

    tables = append(tables, strings.Split(*tabs, ",")...)

    dataSourceName = fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=utf8", *user, *pwd, *addr, *port, *db)
}

func main() {

    count := len(tables)
    ch := make(chan bool, count)

    db, err := sql.Open(driverNameMysql, dataSourceName)
    defer db.Close()
    if err != nil {
        panic(err.Error())
    }

    // Open doesn't open a connection. Validate DSN data:
    err = db.Ping()
    if err != nil {
        panic(err.Error())
    }

    for _, table := range tables {
        go querySQL(db, table, ch)
    }

    for i := 0; i < count; i++ {
        <-ch
    }
    fmt.Println("Done!")
}

func querySQL(db *sql.DB, table string, ch chan bool) {
    fmt.Println("开始处理:", table)
    rows, err := db.Query(fmt.Sprintf("SELECT * from %s", table))

    if err != nil {
        panic(err)
    }

    columns, err := rows.Columns()
    if err != nil {
        panic(err.Error())
    }

    //values:一行的所有值,把每一行的各个字段放到values中,values长度==列数
    values := make([]sql.RawBytes, len(columns))
    // print(len(values))

    scanArgs := make([]interface{}, len(values))
    for i := range values {
        scanArgs[i] = &values[i]
    }

    //存所有行的内容totalValues
    totalValues := make([][]string, 0)
    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))
            // print(len(s))
        }
        totalValues = append(totalValues, s)
    }

    if err = rows.Err(); err != nil {
        panic(err.Error())
    }
    writeToCSV(table+".csv", columns, totalValues)
    ch <- true
}

//writeToCSV
func writeToCSV(file string, columns []string, totalValues [][]string) {
    f, err := os.Create(file)
    // fmt.Println(columns)
    defer f.Close()
    if err != nil {
        panic(err)
    }
    //f.WriteString("\xEF\xBB\xBF")
    w := csv.NewWriter(f)
    for i, row := range totalValues {
        //第一次写列名+第一行数据
        if i == 0 {
            w.Write(columns)
            w.Write(row)
        } else {
            w.Write(row)
        }
    }
    w.Flush()
    fmt.Println("处理完毕:", file)
}

func usage() {
    fmt.Fprint(os.Stderr, helpInfo)
    flag.PrintDefaults()
}

操作示例:

编译代码生成可执行文件:

代码语言:javascript
复制
go build mysqldataexport.go

数据库中有test2库下的test表:

导出其中的数据:

代码语言:javascript
复制
.\mysqldataexport.exe -port=3306 -addr="localhost" -user="root" -pwd="mysql" -db="test2" -tables="test"

导出结果如下:

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-09-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 进击云原生 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档