美文网首页
Golang使用xorm逆向生成结构体(针对MySQL使用)

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

作者: 树先生_张 | 来源:发表于2019-10-02 08:54 被阅读0次

    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使用)

          本文链接:https://www.haomeiwen.com/subject/kzknectx.html