MCPcopy
hub / github.com/xxjwxc/gormt

github.com/xxjwxc/gormt @v2.1.gorm sqlite

repository ↗ · DeepWiki ↗ · release v2.1.gorm ↗
280 symbols 736 edges 41 files 212 documented · 76%
README

Build Status Go Report Card GoDoc Mentioned in Awesome Go

gorm-tools


mysql数据库转 struct 工具,可以将mysql数据库自动生成golang sturct结构,带大驼峰命名规则。带json标签

English

交互界面模式

show

./gormt -g=true

命令行模式

show

./gormt -g=false

安装

go get -u -v github.com/xxjwxc/gormt@master

或者: 下载地址

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

注意:最新的配置请参考 MyIni.go, 或使用命令行工具默认生成的。

base:
    is_dev: false
out_dir: ./model  # 输出目录
url_tag: json # web url tag(json,db(https://github.com/google/go-querystring))
language: 中 文  # 语言(English,中 文)
db_tag: gorm # 数据库标签(gorm,db)
simple: false # 简单输出(默认gorm标签不输出)
is_out_sql: false # 是否输出 sql 原信息
is_out_func: true # 是否输出 快捷函数
is_foreign_key: true # 是否导出外键关联
is_gui: false  # 是否ui模式显示
is_table_name: false # 是否直接生成表名,列名
is_null_to_point: false # 数据库默认 'DEFAULT NULL' 时设置结构为指针类型
is_web_tag: false
is_web_tag_pk_hidden: false
table_prefix: "" #表前缀
db_info:
    host : 127.0.0.1
    port : 3306
    username : root
    password : qwer
    database : oauth_db
    type: 0 # 数据库类型:0:mysql , 1:sqlite , 2:mssql
self_type_define: # 自定义数据类型映射
    datetime: time.Time
    date: time.Time
out_file_name: "" # 自定义生成文件名
web_tag_type: 0 # json tag类型 0: 小驼峰 1: 下划线

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

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

命令行工具默认会生成config.yml, 具体位置为gormt 可执行文件所在目录。 可以通过 which gormt 查找所在目录。

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           是否导出外键关联
  -F, --fun               是否导出函数
  -g, --gui               是否ui显示模式
  -h, --help              help for main
  -H, --host string       数据库地址.(注意-H为大写)
  -o, --outdir string     输出目录
  -p, --password string   密码.
      --port int          端口号 (default 3306)
  -s, --singular          是否禁用表名复数
  -l, --url string        url标签(json,url)
  -u, --user string       用户名.

4. 支持gorm 相关属性

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

您可以在这里丰富数据映射类型 def

5. 示例展示

sql:

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. 支持函数导出(导出函数只是 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

说明:windows 不支持中文默认方式。ASCALL 模式

切换编码方式

CHCP 65001 

列注释 tag

  • 给列添加注释以[@gorm default:'test']开头即可
  • 比如[@gorm default:'test';->;<-:create]这是注释内容 表示默认值为'test',允许读,更新创建
  • 外键注释使用[@fk tableName.columnName]这是注释内容 表示关联到tableNamecolumnName

8. 下一步计划

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

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

图片描述

图片描述

图片描述

图片描述

下载地址

点赞时间线

Stargazers over time

Extension points exported contracts — how you extend this code

IModel (Interface)
IModel Implement the interface to acquire database information and initialize it.实现接口获取数据库信息获取并初始化 [3 implementers]
data/view/model/def_ifs.go
IGenerate (Interface)
IGenerate Generate Printing Interface.生成打印接口 [2 implementers]
data/view/generate/def.go
Option (Interface)
Option overrides behavior of Connect.
data/view/genfunc/model/gen.base.go

Core symbols most depended-on inside this repo

SLocalize
called by 48
data/dlg/i18n.go
Add
called by 26
data/view/generate/generate.go
New
called by 23
data/view/genfunc/model/gen.base.go
GetTableName
called by 17
data/view/genfunc/model/matrix.gen.account.go
AddTag
called by 16
data/view/genstruct/common.go
getCamelName
called by 15
data/view/model/common.go
GetDbInfo
called by 15
data/config/MyIni.go
division
called by 13
data/dlg/common.go

Shape

Function 135
Method 103
Struct 37
Interface 3
FuncType 1
TypeAlias 1

Languages

Go100%

Modules by API surface

data/config/MyIni.go38 symbols
data/view/genfunc/model/matrix.gen.account.go25 symbols
data/view/genstruct/common.go21 symbols
data/view/genfunc/model/matrix.gen.user.go20 symbols
data/dlg/cui.go20 symbols
data/view/genfunc/model/gen.base.go17 symbols
data/view/model/common.go14 symbols
data/view/model/def.go13 symbols
data/dlg/common.go10 symbols
data/view/model/model.go8 symbols
data/view/model/gensqlite/gensqlite.go8 symbols
data/view/model/genmysql/genmysql.go8 symbols

Dependencies from manifests, versioned

github.com/go-playground/universal-translatorv0.17.0 · 1×
github.com/jroimartin/gocuiv0.4.0 · 1×
github.com/leodido/go-urnv1.2.0 · 1×
github.com/nicksnyder/go-i18n/v2v2.0.3 · 1×
github.com/xxjwxc/publicv0.0.0-2021030303451 · 1×
golang.org/x/textv0.3.3 · 1×
gopkg.in/go-playground/assert.v1v1.2.1 · 1×
gopkg.in/go-playground/validator.v9v9.30.2 · 1×
gopkg.in/yaml.v3v3.0.0-2020031310205 · 1×
gorm.io/driver/mysqlv1.0.1 · 1×
gorm.io/driver/sqlitev1.1.4 · 1×

For agents

$ claude mcp add gormt \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact