V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
xxjwxc
V2EX  ›  Go 编程语言

golang 将数据库转换为 gorm 结构

  •  
  •   xxjwxc ·
    xxjwxc · 2020-01-13 16:05:43 +08:00 · 4483 次点击
    这是一个创建于 1536 天前的主题,其中的信息可能已经有所发展或是发生改变。

    gormt

    一款 mysql 数据库转 struct 工具

    out.gif

    1. 通过当前目录 config.toml 文件配置默认配置项

    out_dir : "."  # 输出目录
    singular_table : false  # 表名复数,是否大驼峰构建 参考:gorm.SingularTable
    simple : false #简单输出
    is_out_sql : false # 是否输出 sql 原信息
    is_out_func : true # 是否输出 快捷函数
    is_json_tag : false #是否打 json 标记
    is_foreign_key : true #是否导出外键关联
    mysql_info :
        host : "127.0.0.1"
        port : 3306
        username : "root"
        password : "qwer"
        database : "oauth_db"
    
    

    2. 可以使用命令行工具更新配置项

    ./gormt -H=127.0.0.1 -d=oauth_db -p=qwer -u=root --port=3306
    

    3. 查看帮助

    ./gormt -h
    
    -------------------------------------------------------
    base on gorm tools for mysql database to golang struct
    
    Usage:
      main [flags]
    
    Flags:
      -d, --database string   数据库名
      -h, --help              help for main
      -H, --host string       数据库地址.(注意-H 为大写)
      -o, --outdir string     输出目录
      -p, --password string   密码.
          --port int          端口号 (default 3306)
      -s, --singular          是否禁用表名复数
      -u, --user string       用户名.
      
    

    4. 支持 gorm 相关属性

    • 数据库表,列字段注释支持
    • singular_table 表名复数(大驼峰)
    • json tag json 标签输出
    • gorm.Model 基本模型 支持 gorm.Model 模式导出>>>
    • PRIMARY_KEY 将列指定为主键
    • UNIQUE 将列指定为唯一
    • NOT NULL 将列指定为非 NULL
    • INDEX 创建具有或不带名称的索引, 如果多个索引同名则创建复合索引
    • UNIQUE_INDEX 和 INDEX 类似,只不过创建的是唯一索引
    • 支持外键相关属性 简单带外键模式导出>>>
    • 支持函数导出(包括:外键,关联体,索引关...)简单函数导出示例>>>

    5. 示例展示

    --->导出结果示例
    • 参数:singular_table = false simple = false isJsonTag = true
    //	用户信息
    type UserAccountTbl struct {
    	ID          int       `gorm:"primary_key;column:id;type:int(11);not null" json:"-"`                                                   //
    	Account     string    `gorm:"unique;column:account;type:varchar(64);not null" json:"account"`                                         //
    	Password    string    `gorm:"column:password;type:varchar(64);not null" json:"password"`                                              //
    	AccountType int       `gorm:"column:account_type;type:int(11);not null" json:"account_type"`                                          //	帐号类型:0 手机号,1 邮件
    	AppKey      string    `json:"app_key" gorm:"unique_index:UNIQ_5696AD037D3656A4;column:app_key;type:varchar(255);not null"`            //	authbucket_oauth2_client 表的 id
    	UserInfoID  int       `gorm:"unique_index:UNIQ_5696AD037D3656A4;index;column:user_info_id;type:int(11);not null" json:"user_info_id"` //
    	RegTime     time.Time `gorm:"column:reg_time;type:datetime" json:"reg_time"`                                                          //
    	RegIP       string    `gorm:"column:reg_ip;type:varchar(15)" json:"reg_ip"`                                                           //
    	BundleID    string    `json:"bundle_id" gorm:"column:bundle_id;type:varchar(255)"`                                                    //
    	Describ     string    `gorm:"column:describ;type:varchar(255)" json:"describ"`                                                        //
    }
    
    • 参数:singular_table = false simple = true isJsonTag = false
    --->导出结果
    //	用户信息
    type UserAccountTbl struct {
    	ID          int       `gorm:"primary_key"` //
    	Account     string    `gorm:"unique"`      //
    	Password    string    //
    	AccountType int       //	帐号类型:0 手机号,1 邮件
    	AppKey      string    `gorm:"unique_index:UNIQ_5696AD037D3656A4"`       //	authbucket_oauth2_client 表的 id
    	UserInfoID  int       `gorm:"unique_index:UNIQ_5696AD037D3656A4;index"` //
    	RegTime     time.Time //
    	RegIP       string    //
    	BundleID    string    //
    	Describ     string    //
    }
    

    更多>>>

    6. 支持函数导出(导出函数只是 gorm 的辅助类函数,完全兼容 gorm 相关函数集)

    // FetchByPrimaryKey primay or index 获取唯一内容
    func (obj *_UserAccountTblMgr) FetchByPrimaryKey(ID int) (result UserAccountTbl, err error) {
    	err = obj.DB.Table(obj.GetTableName()).Where("id = ?", ID).Find(&result).Error
    	if err == nil && obj.isRelated {
    		{
    			var info UserInfoTbl // 用户信息
    			err = obj.DB.Table("user_info_tbl").Where("id = ?", result.UserInfoTblID).Find(&info).Error
    			if err != nil {
    				return
    			}
    			result.UserInfoTbl = info
    		}
    	}
    
    	return
    }
    
    

    更多>>>

    函数调用示例>>>

    7. 构建

    make windows
    make linux
    make mac
    

    or

    go generate
    

    8. 下一步计划

    • 更新,删除功能函数添加
    • 优化

    9. 提供一个 windows 可视化工具

    1.png 2.jpg 3.jpg 4.jpg

    下载地址

    9 条回复    2020-02-06 11:04:52 +08:00
    littlewing
        1
    littlewing  
       2020-01-13 17:46:39 +08:00
    手动点赞,之前用过一个 chrome 插件,现在找不着了
    xxjwxc
        2
    xxjwxc  
    OP
       2020-01-13 18:07:03 +08:00
    😝,这个工具是对 gorm 深度定制的。包括函数导出(索引,外键,主键),接头体外键支持,gorm 标签。json 标签。
    sun522198558
        3
    sun522198558  
       2020-01-13 18:10:05 +08:00
    貌似很早就点赞了
    xxjwxc
        4
    xxjwxc  
    OP
       2020-01-13 18:12:40 +08:00   ❤️ 1
    @sun522198558 谢谢,因为最近更新了很多很实用的功能。所以又推广一波。
    sun522198558
        5
    sun522198558  
       2020-01-13 18:13:11 +08:00
    @xie1xiao1jun #4 大佬牛逼
    xxjwxc
        6
    xxjwxc  
    OP
       2020-01-13 18:24:21 +08:00
    @sun522198558

    这次主要添加了快捷功能函数导出功能。函数请看:
    https://github.com/xxjwxc/gormt/blob/master/data/view/genfunc/genfunc_test.go

    绝对开发中非常实用且方便。

    索引,外键都自动构建函数出来。直接使用。

    last : 不是大佬,只是为了社区做一点点贡献。
    DelayNoMore
        7
    DelayNoMore  
       2020-01-18 02:52:25 +08:00 via Android
    牛啊,我有个 table 接近 60 个字段
    xxjwxc
        8
    xxjwxc  
    OP
       2020-01-18 16:04:13 +08:00
    @DelayNoMore 😝,省掉很多手工。这两天在做交互界面
    tairan2006
        9
    tairan2006  
       2020-02-06 11:04:52 +08:00
    老哥,建议不要做 windows 的可视化工具,而是 goland 的插件。

    在 goland 的 database 里右键直接生产 gorm model,做出来我就买:)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2519 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 15:59 · PVG 23:59 · LAX 08:59 · JFK 11:59
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.