Golang

关注公众号 jb51net

关闭
首页 > 脚本专栏 > Golang > go mysql数据类型映射

GO将mysql 中 decimal 数据类型映射到 protobuf的操作方法

作者:CTRA王大大

这篇文章主要介绍了go如何优雅地将 mysql 中 decimal 数据类型映射到 protobuf,本文主要展示一下在 protobuf中 float与double的一个区别,结合实例代码给大家介绍的非常详细,需要的朋友可以参考下

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数据类型映射内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文