完成每一个字段的转换

This commit is contained in:
白茶清欢 2021-10-25 20:58:11 +08:00
parent 3d90296c6a
commit f8e2ab7f5b

View File

@ -11,9 +11,16 @@ import (
"fmt" "fmt"
"strings" "strings"
"git.zhangdeman.cn/zhangdeman/gopkg/util"
"github.com/xwb1989/sqlparser" "github.com/xwb1989/sqlparser"
) )
const (
// CreateSQLColumnTPL 每个字段的模版
CreateSQLColumnTPL = "{FIELD} {TYPE} `json:\"{JSON_TAG}\" gorm:\"column:{COLUMN};default:{DEFAULT_VALUE};{NOT_NULL}\"` // {COMMENT}"
)
// ParseCreateTableSql 解析建表sql // ParseCreateTableSql 解析建表sql
// //
// Author : go_developer@163.com<白茶清欢> // Author : go_developer@163.com<白茶清欢>
@ -32,12 +39,25 @@ func ParseCreateTableSql(sql string) {
r := stmt.(*sqlparser.DDL) r := stmt.(*sqlparser.DDL)
for _, item := range r.TableSpec.Columns { for _, item := range r.TableSpec.Columns {
defaultV := item.Type.Default data := map[string]string{
defaultVal := "-" "{FIELD}": util.SnakeCaseToCamel(item.Name.String()),
if nil != defaultV { "{COLUMN}": item.Name.String(),
defaultVal += string(defaultV.Val) + "-" "{JSON_TAG}": item.Name.String(),
"{DEFAULT_VALUE}": "",
"{COMMENT}": item.Name.String() + " " + string(item.Type.Comment.Val),
"{TYPE}": sqlTypeMap[item.Type.Type],
} }
fmt.Println(item.Name.String(), defaultVal, item.Type.NotNull, string(item.Type.Comment.Val)) if item.Type.NotNull {
data["{NOT_NULL}"] = "NOT NULL"
}
if nil != item.Type.Default {
data["{DEFAULT_VALUE}"] += string(item.Type.Default.Val)
}
val := CreateSQLColumnTPL
for k, v := range data {
val = strings.ReplaceAll(val, k, v)
}
fmt.Println(val)
} }
// fmt.Println(r.TableSpec) // fmt.Println(r.TableSpec)
} }