mysql表結構自動生成golang struct


安裝

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='用戶表'

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"
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM