根据mysql表结构自动生成go struct

当我们用Go做数据库相关操作时,编写出和表对应的结构体是必做的事情,例如

type ServiceRecommend struct {
   Id              int64  `gorm:"id" json:"id"`                               // id
   ShopId          int64  `gorm:"shop_id" json:"shop_id"`                     // shopID
   MarketServiceId int64  `gorm:"market_service_id" json:"market_service_id"` // 服务市场服务id
   Status          int64  `gorm:"status" json:"status"`                       // 推荐状态 1推荐 2取消推荐
   CreateBy        string `gorm:"create_by" json:"create_by"`                 // 创建人
   CreateTime      string `gorm:"create_time" json:"create_time"`             // 创建时间
   UpdateBy        string `gorm:"update_by" json:"update_by"`                 // 更新人
   UpdateTime      string `gorm:"update_time" json:"update_time"`             // 更新时间
}

这里简单介绍一下gorm和json字段。其中用gorm设置key的特性,如主键、长度等。json用来设置在struct作为json输出的时候,key的名称,如果不设置,默认与导出字段一致。

编写struct没什么技术含量,完全是重复工作。基于重复事情做三次,就要自动化的原则,从github上找到了解决方案。

其实对于解决这个问题的代码挺多,这里提供相对方便且功能强大的,代码库github.com/gohouse/converter,使用方法:

package main

import (
   "fmt"
   "github.com/gohouse/converter"
)
func main() {
   err := converter.NewTable2Struct().
      SavePath("./model.go").
      Dsn("用户名:密码@tcp(IP:端口号)/数据库名?charset=utf8").
      TagKey("gorm").
      EnableJsonTag(true).
      Table("表名").
      Run()
   fmt.Println(err)
}

SavePath为输出结果存放文件

DSN用于配置数据库的信息

TagKey用于配置Tag,此处写为gorm

EnableJsonTag用于确认是否输出时有json标签

Table用于指定表,如果不写则输出库中的所有表

文章开始处的struct就是用该代码生成的,是不是方便了很多。

总结

程序员理应是懒人,需要用技术来提高效率,做到虽然懒但是也能开心生活。

资料

  1. https://blog.csdn.net/QrrrQ/article/details/73196378
  2. https://studygolang.com/articles/16393?fr=sidebar

最后

大家如果喜欢我的文章,可以关注我的公众号(程序员麻辣烫)

我的个人博客为:https://shidawuhen.github.io/

往期文章回顾:

设计模式

  1. Go设计模式(5)-类图符号表示法
  2. Go设计模式(4)-代码编写优化
  3. Go设计模式(4)-代码编写
  4. Go设计模式(3)-设计原则
  5. Go设计模式(2)-面向对象分析与设计
  6. Go设计模式(1)-语法

语言

  1. Go工具之generate
  2. Go单例实现方案
  3. Go通道实现原理
  4. Go定时器实现原理
  5. Beego框架使用
  6. Golang源码BUG追查
  7. Gin框架简洁版
  8. Gin源码剖析

架构

  1. 支付接入常规问题
  2. 限流实现2
  3. 秒杀系统
  4. 分布式系统与一致性协议
  5. 微服务之服务框架和注册中心
  6. 浅谈微服务
  7. 限流实现1
  8. CDN请求过程详解
  9. 常用缓存技巧
  10. 如何高效对接第三方支付
  11. 算法总结

存储

  1. MySQL开发规范
  2. Redis实现分布式锁
  3. 事务原子性、一致性、持久性的实现原理
  4. InnoDB锁与事务简析

网络

  1. HTTP2.0基础教程
  2. HTTPS配置实战
  3. HTTPS连接过程
  4. TCP性能优化

读书笔记

  1. 原则
  2. 资治通鉴
  3. 敏捷革命
  4. 如何锻炼自己的记忆力
  5. 简单的逻辑学-读后感
  6. 热风-读后感
  7. 论语-读后感
  8. 孙子兵法-读后感

思考

  1. 为动员一切力量争取抗战胜利而斗争
  2. 反对自由主义
  3. 实践论
  4. 评价自己的标准
  5. 服务端团队假期值班方案
  6. 项目流程管理
  7. 对项目管理的一些看法
  8. 对产品经理的一些思考
  9. 关于程序员职业发展的思考
  10. 关于代码review的思考
  11. Markdown编辑器推荐-typora
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值