您现在的位置是:网站首页> 编程资料编程资料
GO将mysql 中 decimal 数据类型映射到 protobuf的操作方法_Golang_
2023-05-26
422人已围观
简介 GO将mysql 中 decimal 数据类型映射到 protobuf的操作方法_Golang_
protobuf中 float与double
1、如何在rpc中优雅取出dcemial类型
例如我们在mysql中定义的一个字段如下:
`discount` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '折扣',
2、在rpc中 proto我们定义如下
这里主要展示一下在 protobuf中 float与double的一个区别
2.1、proto - double
*.proto文件如下:
message Price { double discount = 1; // 折扣 }我们来看一下定义为double生成的实体类为
通过go-zero直接生成的*_pb.go文件如下:
type Price struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields Discount float64 `protobuf:"fixed64,6,opt,name=discount,proto3" json:"discount"` // 折扣 }2.2、proto - float
*.proto文件如下:
message Price { float discount = 1; // 折扣 }我们来看一下定义为double生成的实体类为
通过go-zero直接生成的*_pb.go文件如下:
type Price struct { state protoimpl.MessageState sizeCache protoimpl.SizeCache unknownFields protoimpl.UnknownFields Discount float32 `protobuf:"fixed32,1,opt,name=discount,proto3" json:"discount"` // 折扣 }3、在go-zero的sqlx中生成的model
结论:sqlx将decimal类型生成float64类型的struct
对应我们的第一条mysql的decimal类型通过
orm生成model指令:
goctl model mysql datasource -url="root:123@tcp(127.0.0.1:3306)/数据库名" -table="xxx" -dir=./internal/model

到此这篇关于go如何优雅地将 mysql 中 decimal 数据类型映射到 protobuf的文章就介绍到这了,更多相关go mysql数据类型映射内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- 基于Golang实现延迟队列(DelayQueue)_Golang_
- go pprof 的使用操作代码_Golang_
- Go语言开发框架反射机制及常见函数示例详解_Golang_
- Windows系统中搭建Go语言开发环境图文详解_Golang_
- golang中的defer函数理解_Golang_
- Go语言k8s kubernetes使用leader election实现选举_Golang_
- Golang迭代如何在Go中循环数据结构使用详解_Golang_
- Golang底层原理解析String使用实例_Golang_
- 详解如何在Go语言中循环数据结构_Golang_
- golang中的nil接收器详解_Golang_
