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

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

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、Python简介和环境搭建以及pip的安装 4课时实验课主要内容 【Python简介】: Python 是一个...
    _小老虎_阅读 5,883评论 0 10
  • 环境搭建 Golang在Mac OS上的环境配置 使用Visual Studio Code辅助Go源码编写 VS ...
    陨石坠灭阅读 5,797评论 0 5
  • 1、请对待你的父母像对待你的孩子一样耐心 有一天早晨正在给女儿换尿湿的衣服,母亲打电话来让我教她使用微信,母亲年纪...
    子夜海蓝阅读 332评论 0 0
  • 今天生意很差,所以利用朋友圈做了一点营销活动,这两天会跟进一下! 中午到老员工家聚餐,增进团队友谊。下午把员工宿舍...
    乐平朝天门阅读 74评论 0 0
  • 以前上学的时候,很喜欢看小说,羡慕书里女主角众星捧月,是男生就喜欢,是女生就嫉妒,后来知道了有一种东西叫做「主角光...
    米兰的小小铁匠阅读 269评论 0 0