mysql表結構自動生成golang struct

fizz發表於2018-11-21

a lib for golang , generate mysql table schema to golang struct

mysql表結構自動生成golang struct

github地址

https://github.com/gohouse/converter

安裝

  1. 直接下載可執行檔案: 下載地址
  2. golang原始碼包: go get github.com/gohouse/converter

示例表結構

CREATE TABLE `prefix_user` (
  `Id` int(11) NOT NULL AUTO_INCREMENT,
  `Email` varchar(32) NOT NULL DEFAULT `` COMMENT `郵箱`,
  `Password` varchar(32) NOT NULL DEFAULT `` COMMENT `密碼`,
  `CreatedAt` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`Id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT=`使用者表`

命令列用法

  1. 下載對應平臺的可執行檔案, 下載地址
  2. 命令列執行

    # 檔名: table2struct-[$platform].[$version].[$suffix]
    ./table2struct-linux.v0.0.3.bin -file model.go -dsn xxx -table user
  3. 引數說明
-dsn            string 資料庫dsn配置
-enableJsonTag  bool 是否新增json的tag
-file           string 儲存路徑
-packageName    string 包名
-prefix         string 表字首
-realNameMethod string 結構體對應的表名
-table          string 要遷移的表
-tagKey         string tag的key

golang程式碼簡單用法

package main
import (
    "fmt"
    "github.com/gohouse/converter"
)
func main() {
    err := converter.NewTable2Struct().
        SavePath("/home/go/project/model/model.go").
        Dsn("root:root@tcp(localhost:3306)/test?charset=utf8").
        Run()
    fmt.Println(err)
}

golang程式碼詳細用法示例

package main

import (
    "fmt"
    "github.com/gohouse/converter"
)

func main() {
    // 初始化
    t2t := converter.NewTable2Struct()
    // 個性化配置
    t2t.Config(&converter.T2tConfig{
        // 如果欄位首字母本來就是大寫, 就不新增tag, 預設false新增, true不新增
        RmTagIfUcFirsted: false,
        // tag的欄位名字是否轉換為小寫, 如果本身有大寫字母的話, 預設false不轉
        TagToLower: false,
        // 欄位首字母大寫的同時, 是否要把其他字母轉換為小寫,預設false不轉換
        UcFirstOnly: false,
        //// 每個struct放入單獨的檔案,預設false,放入同一個檔案(暫未提供)
        //SeperatFile: false,
    })
    // 開始遷移轉換
    err := t2t.
        // 指定某個表,如果不指定,則預設全部表都遷移
        Table("user").
        // 表字首
        Prefix("prefix_").
        // 是否新增json tag
        EnableJsonTag(true).
        // 生成struct的包名(預設為空的話, 則取名為: package model)
        PackageName("model").
        // tag欄位的key值,預設是orm
        TagKey("orm").
        // 是否新增結構體方法獲取表名
        RealNameMethod("TableName").
        // 生成的結構體儲存路徑
        SavePath("/Users/fizz/go/src/github.com/gohouse/gupiao/model/model.go").
        // 資料庫dsn,這裡可以使用 t2t.DB() 代替,引數為 *sql.DB 物件
        Dsn("root:root@tcp(localhost:3306)/test?charset=utf8").
        // 執行
        Run()
    
    fmt.Println(err)
}

result

package model

import "time"

type User struct {
    Id         int     `json:"Id" orm:"Id"`
    Email      string  `json:"Email" orm:"Email"`           // 郵箱
    Password   string  `json:"Password" orm:"Password"`     // 密碼
    CreatedAt  string  `json:"CreatedAt" orm:"CreatedAt"`
}

func (*User) TableName() string {
    return "user"
}

相關文章