完成每一个字段的转换
This commit is contained in:
		@ -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)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user