分享
  1. 首页
  2. 文章

Golang使用xorm逆向生成结构体(针对MySQL使用)

aside section ._1OhGeD · · 2475 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

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


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:aside section ._1OhGeD

查看原文:Golang使用xorm逆向生成结构体(针对MySQL使用)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
2475 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏