go语言 | 快速生成数据库表的 model 和 queryset

2024-06-13 01:44

本文主要是介绍go语言 | 快速生成数据库表的 model 和 queryset,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

就是生成 model 目录的 xxx.go 和 xxx_gen.go 文件

使用的工具:
快速生成 model:gentool:https://github.com/go-gorm/gen/tree/master/tools/gentool
根据 model 生成 queryset:go-queryset:https://github.com/jirfag/go-queryset/


概叙

Golang 操作数据库表时,可能经常需要创建像下图中所示的与数据表相对应的 struct 对象,常被称为 model,有同学可能会说,model 也没几个字段,手写不就好了,没必要用工具来生成。当数据库表比较少,且表的字段少时用手敲确实可以完成,但是如果需要生成model的表数量比较多,每个model的字段也比较多,这时是用工具来生成可能是个更合适的选择,也更不容易出错。所以这里介绍一个能快速生成 model 文件和 queryset 的方法。

在这里插入图片描述
先安装下载 gentool 工具

go install gorm.io/gen/tools/gentool@latest

执行下面这一条命令即可生成与数据表相对应的 model 文件,命令的用法参考下面的“案例演示”。

gentool -dsn "user:pwd@tcp(127.0.0.1:3306)/database?charset=utf8mb4&parseTime=True&loc=Local" -tables "student"  -onlyModel

案例演示

1、生成 model 文件
比如我想给student表生成 model ,student 表有下面这些字段。

CREATE TABLE `student`(`id` BIGINT(20) UNSIGNED not NULL AUTO_INCREMENT COMMENT '自增id',`school_id` BIGINT(20) NOT NULL DEFAULT '0' COMMENT '学号',`name` VARCHAR(64) NOT NULL DEFAULT '0' COMMENT '姓名',`male` TINYINT(4) NOT NULL DEFAULT '0' COMMENT '性别',`phone_number` BIGINT(20) NOT NULL DEFAULT '0' COMMENT '手机号',`addr` VARCHAR(255) NOT NULL DEFAULT '' COMMENT '家庭住址',`class` VARCHAR(255) NOT NULL DEFAULT '0' COMMENT '班级',`major` INT NOT NULL DEFAULT '0' COMMENT '专业id',`grade` INT NOT NULL DEFAULT '0' COMMENT '入学年份/年级',`extra` text NOT NULL DEFAULT '' COMMENT '其他',`create_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`modify_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',PRIMARY KEY (`id`)
) ENGINE=INNODB DEFAULT CHARSET=utf8 COMMENT='学生基本信息表';

使用如下命令生成model,model文件会生成在当前路径上一级的名为model的文件夹中,比如在demo/aaa下执行上面的命令,那么 model 会生成在 demo/model 路径下,如果 model 路径不存在会自动创建。

gentool -dsn "root:123456@tcp(127.0.0.1:3306)/my_test_db?charset=utf8mb4&parseTime=True&loc=Local" -tables "student"  -onlyModel

命令执行完毕后,会发现在 demo 路径下生成了 一个名为 model 的文件夹,文件夹里有个 student.gen.go 文件,这个就是我们刚才生成的 model 文件了

在这里插入图片描述
如果想指定 model 文件的路径,需要添加 -modelPkgName 参数,完整命令如下所示,执行完毕后,model 文件将生成在 aaa 路径下,需要注意 -modelPkgName 的路径需要是绝对路径,不能是相对路径。

gentool -dsn "root:123456@tcp(127.0.0.1:3306)/my_test_db?charset=utf8mb4&parseTime=True&loc=Local" -tables "student"  -onlyModel -modelPkgName="/Users/luochunhui/go/src/demo/aaa" 

修改文件名

我们一般习惯于把 student.gen.go这个model 文件中的 ‘.gen’ 字符串去除,也就是重命名为 student.go


model 文件添加必要注释

接下来需要用 model 文件生成 queryset 文件,也就是我们经常看到的以 ‘_gen.go’ 结尾的文件,生成 queryset 文件前,需要在 model 文件中添加 2 行注释,虽然是注释,但是这两行注释必不可少。

student.go 是当前model 文件的文件名,student_gen.go 是将要生成的 queryset 文件的文件名

//go:generate goqueryset -in student.go -out student_gen.go

下面这行日志必须放在model struct正上方第一行。

// gen:qs

在这里插入图片描述

安装 goqueryset

执行下面的命令进行 goqueryset 工具安装

go get -u github.com/jirfag/go-queryset/cmd/goqueryset
# 如果上面的 go get 命令安装 goqueryset 失败,可以尝试下面这条命令,如果成功了就不用尝试了
go install github.com/jirfag/go-queryset/cmd/goqueryset@latest

生成 queryset 文件

注释添加完毕后,进入到 model 文件所在路径,执行下面的命令来生成 queryset 文件。

go generate ./...

执行完毕可以看到与 model 文件同级目录下生成了一个 student_gen.go 文件,这个文件就是 queryset 文件。

在这里插入图片描述

最后

在生成的queryset 可以看到 github.com/jinzhu/gorm这个依赖还没安装,执行下面的命令拉取即可,拉取完毕应该就不报错了。

go get github.com/jinzhu/gorm
go mod tidy

在这里插入图片描述

@ sqllite方式

脚本

创建makefile

# 命令
gen:gentool -dsn "root:123456@tcp(192.168.1.13:3306)/bk?charset=utf8mb4&parseTime=True&loc=Local" -outPath "./bkmodel/dao/query"

make gen运行展示

root@tdev:/home/code/tapi# make gen
gentool -dsn "root:123456@tcp(192.168.1.13:3306)/bk?charset=utf8mb4&parseTime=True&loc=Local" -outPath "./bkmodel/dao/query"
2023/02/11 07:19:53 got 6 columns from table <user>
2023/02/11 07:19:53 Start generating code.
2023/02/11 07:19:53 generate model file(table <user> -> {model.User}): /home/code/tapi/bkmodel/dao/model/user.gen.go
2023/02/11 07:19:53 generate query file: /home/code/tapi/bkmodel/dao/query/user.gen.go
2023/02/11 07:19:53 generate query file: /home/code/tapi/bkmodel/dao/query/gen.go
2023/02/11 07:19:53 Generate code done.

时区有问题改一下

sudo timedatectl set-timezone Asia/Shanghai// 检查
root@tdev:/home/code/tapi# sudo timedatectl set-timezone Asia/Shanghai
root@tdev:/home/code/tapi# timedatectlLocal time: Sat 2023-02-11 15:31:07 CSTUniversal time: Sat 2023-02-11 07:31:07 UTCRTC time: Sat 2023-02-11 07:31:07Time zone: Asia/Shanghai (CST, +0800)
System clock synchronized: yesNTP service: activeRTC in local TZ: no

参考

https://blog.51cto.com/u_14201949/5376011
https://juejin.cn/post/7199191689150971959

这篇关于go语言 | 快速生成数据库表的 model 和 queryset的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1055938

相关文章

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Go之errors.New和fmt.Errorf 的区别小结

《Go之errors.New和fmt.Errorf的区别小结》本文主要介绍了Go之errors.New和fmt.Errorf的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考... 目录error的基本用法1. 获取错误信息2. 在条件判断中使用基本区别1.函数签名2.使用场景详细对

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

Go中select多路复用的实现示例

《Go中select多路复用的实现示例》Go的select用于多通道通信,实现多路复用,支持随机选择、超时控制及非阻塞操作,建议合理使用以避免协程泄漏和死循环,感兴趣的可以了解一下... 目录一、什么是select基本语法:二、select 使用示例示例1:监听多个通道输入三、select的特性四、使用se