当需要使用数据库查询,或者调用第三方接口返回json数据时,是不是经常需要自定义struct 结构体进行映射。
但是在定义golang结构体的时候是不是会感觉特别浪费时间,而且还经常会应为大意而导致出错?
那么接下来的两个工具将会为你的结构体定义提供“革命性”的解决方法;
1 JSON-To-Stuct 工具
生成JSON数据映射的结构体在线工具 https://mholt.github.io/json-to-go/
这个在线工具使用起来非常简单,只需要将JSON数据粘贴在左边,就会在右边自动成生成对应的结构体定义:
这个功能在 21 版的goland中支持了。在goland中你可以使用如下 *** 作生成struct
2 Table-To-Stuct
工作中大家会被大量CURD *** 作缠身。数据表中的字段总得在代码中定义struct模型吧。总不能又一个个字段定义,那么下面这个工具可以帮大家节省很多时间。
源码参考地址
假设有如下数据表:
CREATE TABLE `prefix_user` (
`Id` int(11) NOT NULL AUTO_INCREMENT,
`Email` varchar(32) NOT NULL DEFAULT '' COMMENT '邮箱',
`Password` varchar(32) NOT NULL DEFAULT '' COMMENT '密码',
`CreatedAt` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (`Id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户表'
使用下边的代码可以自动生成上述表结构对应的结构体
/*
@ Time : 2021/08/08 23:41
@ Author : qyz
@ File : main
@ Software: GoLand
@ Description: 利用数据库中的数据表字段自动生成struct
*/
package main
import (
"fmt"
"github.com/gohouse/converter"
)
func main() {
// 初始化
t2t := converter.NewTable2Struct()
// 个性化配置
t2t.Config(&converter.T2tConfig{
// 如果字段首字母本来就是大写, 就不添加tag, 默认false添加, true不添加
RmTagIfUcFirsted: false,
// tag的字段名字是否转换为小写, 如果本身有大写字母的话, 默认false不转
TagToLower: false,
// 字段首字母大写的同时, 是否要把其他字母转换为小写,默认false不转换
UcFirstOnly: false,
每个struct放入单独的文件,默认false,放入同一个文件(暂未提供)
//SeperatFile: false,
})
// 开始迁移转换
err := t2t.
// 指定某个表,如果不指定,则默认全部表都迁移
Table("user").
// 表名前缀
Prefix("prefix_").
// 是否添加json tag
EnableJsonTag(true).
// 生成struct的包名(默认为空的话, 则取名为: package model)
PackageName("model").
// tag字段的key值,默认是orm
TagKey("orm").
// 是否添加结构体方法获取表名
RealNameMethod("TableName").
// 生成的结构体保存路径
SavePath("99_工具类/08_数据表自动生成结构体/result/model.go").
// 数据库dsn,这里可以使用 t2t.DB() 代替,参数为 *sql.DB 对象
// "用户名:密码@tcp(数据库地址:端口号)/数据库名?charset=utf8"
Dsn("root:aaaaaa@tcp(192.168.0.150:3306)/mybatis_plus?charset=utf8").
// 执行
Run()
fmt.Println(err)
}
自动生成结果:
package model
type User struct {
Id int `orm:"Id" json:"Id"`
Email string `orm:"Email" json:"Email"` // 邮箱
Password string `orm:"Password" json:"Password"` // 密码
CreatedAt string `orm:"CreatedAt" json:"CreatedAt"`
}
func (*User) TableName() string {
return "user"
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)