Skip to content

xxjwxc/gormt

Repository files navigation

Build Status Go Report Card GoDoc Mentioned in Awesome Go

mysql database to golang struct conversion tools base ongorm(v1/v2),You can automatically generate golang sturct from mysql database. big Camel-Case Name Rule, JSON tag.

gui support

show

./gormt -g=true

cmd support

show

./gormt -g=false

install

go get -u -v github /xxjwxc/gormt@latest

or:Dowloading


1. Configure default configuration items through the current directory config.yml file

note: for latest version of config format, please check /data/config/MyIni.go

out_dir:"./model"#out dir
url_tag:json#web url tag(json,db(https://github /google/go-querystring))
language:#language(English, trung văn )
db_tag:gorm#DB tag(gorm,db)
simple:false#simple output
is_out_sql:false#Whether to output sql
is_out_func:true#Whether to output function
is_foreign_key:true#Whether to mark foreign key or not
is_gui:false#Whether to operate on gui
is_table_name:false#Whether to out GetTableName/column function
is_null_to_point:false#database is 'DEFAULT NULL' then set element type as point
is_web_tag:false
is_web_tag_pk_hidden:false
table_prefix:""#table prefix
table_names:""#Specified table generation, multiple tables with, separated
is_column_name:true#Whether to generate column names
is_out_file_by_table_name:false#Whether to generate multiple models based on table names
db_info:
host:"127.0.0.1"
port:3306
username:"root"
password:"qwer"
database:"oauth_db"
type:0#database type (0:mysql, 1:sqlite, 2:mssql)
self_type_define:#Custom data type mapping
datetime:time.Time
date:time.Time
out_file_name:""#Custom build file name
web_tag_type:0#json tag 0: Small Camel-Case 1: _

2. get help

./gormt --help
or
./gormt -h

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

Usage:
main [flags]

Flags:
-d, --database string cơ sở dữ liệu danh
-f, --foreign hay không đạo xuất ngoại kiện liên hệ
-F, --fun hay không đạo ra hàm số
-g, --gui hay không ui biểu hiện hình thức
-h, --help help for main
-H, --host string cơ sở dữ liệu địa chỉ.( chú ý -H vì viết hoa )
-o, --outdir string phát ra mục lục
-p, --password string mật mã.
--port int cảng hào (default 3306)
-s, --singular hay không cấm dùng biểu danh số nhiều
-b, --table_names string biểu tên
-l, --url string url nhãn (json,url)
-u, --user string username.

3. Can be updated configuration items using command line tools

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

4. Support for gorm attributes

  • Database tables, column field annotation support
  • json tag json tag output
  • gorm.ModelSupport export gorm.model>>>
  • PRIMARY_KEY Specifies column as primary key
  • UNIQUE Specifies column as unique
  • NOT NULL Specifies column as NOT NULL
  • INDEX Create index with or without name, same name creates composite indexes
  • UNIQUE_INDEX Like INDEX, create unique index
  • Support foreign key related propertiesSupport export gorm.model>>>
  • Support function export (foreign key, association, index, unique and more)Support export function >>>
  • model.Condition{} sql link

You can enrich data types indef

5. Demonstration

  • 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 ' account loại hình:0 số di động, 1 bưu kiện ',
`app_key` varchar(255) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT 'authbucket_oauth2_client biểu 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=' người dùng tài khoản '
--->Derived results
// UserAccountTbl người dùng tài khoản
type UserAccountTbl struct {
ID int `gorm: "primary_key" `
Account string `gorm: "unique" `
Password string
AccountType int // account loại hình:0 số di động, 1 bưu kiện
AppKey string // authbucket_oauth2_client biểu id
UserInfoTblID int `gorm: "index" `
UserInfoTbl UserInfoTbl `gorm: "association_foreignkey:user_info_tbl_id;foreignkey:id" ` // người dùng tin tức
RegTime time.Time
RegIP string
BundleID string
Describ string
}

6. support func export

The exported function is only the auxiliary class function of Gorm, and calls Gorm completely

// FetchByPrimaryKey primary or index thu hoạch duy nhất nội dung
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 // người dùng tin tức
err = obj.DB.Table( "user_info_tbl" ).Where( "id =?", result.UserInfoTblID).Find(&info).Error
if err!= nil {
return
}
result.UserInfoTbl = info
}
}

return
}

7. page

8. build

make windows
make linux
make mac

or

go generate

note: in windows not support utf-8 style. ASCALL model

  • Switch encoding mode
CHCP 65001

column notes default

  • Add a comment to the column starting with[@gorm default:'test']
  • example[@gorm default:'test';->;<-:create]this is my notesIndicates that the default value is 'test',can read/creat/write
  • Use of foreign key notes[@fk tableName.columnName]this is my notesRepresents the 'columnName' column associated with the 'tableName'

9. one windows gui tools

1

2

3

4

Download

Stargazers over time

Stargazers over time