golang 將數據庫轉換爲gorm結構

gormt


一款mysql數據庫轉 struct 工具,能夠將mysql數據庫自動生成golang sturct結構,帶大駝峯命名規則。帶json標籤mysql


1. 經過當前目錄 config.yml 文件配置默認配置項

out_dir : "."  # 輸出目錄
singular_table : false  # 表名複數,是否大駝峯構建 參考:gorm.SingularTable
simple : false #簡單輸出
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 --help
or
./gormt -h

-------------------------------------------------------
base on gorm tools for mysql database to golang struct

Usage:
  main [flags]

Flags:
  -d, --database string   數據庫名
  -f, --foreign           是否導出外鍵關聯
  -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 相似,只不過建立的是惟一索引
  • 支持外鍵相關屬性 簡單帶外鍵模式導出>>>

您能夠在這裏豐富數據映射類型 def

5. 示例展現

sql:linux

CREATE TABLE `user_account_tbl` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `account` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `password` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `account_type` int(11) NOT NULL DEFAULT '0' COMMENT '賬號類型:0手機號,1郵件',
  `app_key` varchar(255) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT 'authbucket_oauth2_client表的id',
  `user_info_tbl_id` int(11) NOT NULL,
  `reg_time` datetime DEFAULT NULL,
  `reg_ip` varchar(15) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  `bundle_id` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  `describ` varchar(255) CHARACTER SET utf8 COLLATE utf8_unicode_ci DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE,
  UNIQUE KEY `account` (`account`) USING BTREE,
  KEY `user_info_id` (`user_info_tbl_id`) USING BTREE,
  CONSTRAINT `user_account_tbl_ibfk_1` FOREIGN KEY (`user_info_tbl_id`) REFERENCES `user_info_tbl` (`id`) ON DELETE RESTRICT ON UPDATE RESTRICT
) ENGINE=InnoDB AUTO_INCREMENT=38 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci COMMENT='用戶帳號'
--->導出結果
// UserAccountTbl 用戶帳號
type UserAccountTbl struct {
    ID            int    `gorm:"primary_key"`
    Account       string `gorm:"unique"`
    Password      string
    AccountType   int         // 賬號類型:0手機號,1郵件
    AppKey        string      // authbucket_oauth2_client表的id
    UserInfoTblID int         `gorm:"index"`
    UserInfoTbl   UserInfoTbl `gorm:"association_foreignkey:user_info_tbl_id;foreignkey:id"` // 用戶信息
    RegTime       time.Time
    RegIP         string
    BundleID      string
    Describ       string
}

更多>>>

6. 構建

make windows
make linux
make mac

orgit

go generate

7. 下一步計劃

  • 加入相關快捷函數(OrmFunc)

8. 提供一個windows 可視化工具

在這裏插入圖片描述
在這裏插入圖片描述

在這裏插入圖片描述
在這裏插入圖片描述

下載地址github

7. 下一步計劃

  • 加入相關快捷函數(OrmFunc)
  • 傳送門
相關文章
相關標籤/搜索