Golang使用xorm逆向生成结构体(针对MySQL使用,转成json形式)

Mac Windows平台适用

1.安装包

go get github.com/go-xorm/cmd/xorm
go get github.com/go-xorm/xorm

进入到该目录下

GOPATH\src\github.com\go-xorm\cmd\xorm

xorm.png

使用示例:

xorm reverse mysql name:password@(ip:port)/xxx?charset=utf8  ./templates/goxorm/  自定义文件夹名称
Mac平台用户需要进行转义:
xorm reverse mysql root:L123@\(127.0.0.1:3306\)/test?charset=utf8 ./templates/goxorm/  自定义文件夹名称
windows平台:
xorm reverse mysql root:L123@(127.0.0.1:3306)/test?charset=utf8 ./templates/goxorm/  自定义文件夹名称

执行完成以后你就发现在该目录下新生成一个文件夹,里面有你需要的结构体

如果需要改成json形式的结构体需要更改xorm源码
进入到xorm目录下

GOPATH\src\github.com\go-xorm\cmd\xorm

更改go.go文件从第三百行开始

/*	if genJson {                                                     // 注释
		if include(ignoreColumnsJSON, col.Name) {					 // 注释
			tags = append(tags, "json:\"-\"")						 // 注释
		} else {													 // 注释
			tags = append(tags, "json:\""+col.Name+"\"")			 // 注释
		}															 // 注释
	}																 // 注释
	if len(res) > 0 {												 // 注释
		tags = append(tags, "xorm:\""+strings.Join(res, " ")+"\"")	 // 注释
	}																 // 注释
	if len(tags) > 0 {												 // 注释
		return "`" + strings.Join(tags, " ") + "`"					 // 注释
	} else {														 // 注释
		return ""													 // 注释
	}*/																 // 注释

	if genJson {                                                                		// 新增
		if include(ignoreColumnsJSON, col.Name) {                  						// 新增
			tags = append(tags, "json:\"-\"")                           		        // 新增
		} else {                                                                		// 新增
			tags = append(tags, "json:\""+transfer(col.Name)+"\"")      		        // 新增
																						// 新增
		}                                                           					// 新增
	}																					// 新增
	if len(res) > 0 {																	// 新增
		tags = append(tags, "json:\""+transfer(col.Name)+"\"")							// 新增
	}																					// 新增
	if len(tags) > 0 {																	// 新增
		return "`" + strings.Join(tags, " ") +  "`" + "  " + "//" + " "+ strings.Join(res, " ")   // 新增
	} else {																			// 新增
		return ""																		// 新增
	}																					// 新增

}

// 新增函为改变驼峰式命名
func transfer(s string) string {											// 新增
	data := make([]byte, 0, len(s))											// 新增
	j := false																// 新增
	k := false																// 新增
	num := len(s) - 1														// 新增
	for i := 0; i <= num; i++ {												// 新增
		d := s[i]															// 新增
		if k == false && d >= 'A' && d <= 'Z' {								// 新增
			k = true														// 新增
		}																	// 新增
		if d >= 'a' && d <= 'z' && (j || k == false) {						// 新增
			if i != 0 {														// 新增
				d = d - 32													// 新增
			}																// 新增
			j = false														// 新增
			k = true														// 新增
		}																	// 新增
		if k && d == '_' && num > i && s[i+1] >= 'a' && s[i+1] <= 'z' {		// 新增
			j = true														// 新增
			continue														// 新增
		}																	// 新增
		data = append(data, d)												// 新增
	}																		// 新增
	return string(data[:])													// 新增
}																			// 新增

完整文件放到了GitHub上,下载到本地后直接替换。
https://github.com/zhanghongzhuang/photo.git

你可能感兴趣的:(Golang使用xorm逆向生成结构体(针对MySQL使用,转成json形式))