Go 根据 数据库中表字段Json 快速生成结构体

Go 根据 数据库中表字段Json 快速生成结构体,第1张

当需要使用数据库查询,或者调用第三方接口返回json数据时,是不是经常需要自定义struct 结构体进行映射。
但是在定义golang结构体的时候是不是会感觉特别浪费时间,而且还经常会应为大意而导致出错?
那么接下来的两个工具将会为你的结构体定义提供“革命性”的解决方法;

目录 1 JSON-To-Stuct 工具2 Table-To-Stuct



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"
}

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/langs/995295.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存