GO將mysql?中?decimal?數(shù)據(jù)類型映射到?protobuf的操作方法
protobuf中 float與double
1、如何在rpc中優(yōu)雅取出dcemial類型
例如我們在mysql中定義的一個字段如下:
`discount` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '折扣',
2、在rpc中 proto我們定義如下
這里主要展示一下在 protobuf中 float與double的一個區(qū)別
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
結(jié)論:sqlx將decimal類型生成float64類型的struct
對應我們的第一條mysql的decimal類型通過
orm生成model指令:
goctl model mysql datasource -url="root:123@tcp(127.0.0.1:3306)/數(shù)據(jù)庫名" -table="xxx" -dir=./internal/model

到此這篇關于go如何優(yōu)雅地將 mysql 中 decimal 數(shù)據(jù)類型映射到 protobuf的文章就介紹到這了,更多相關go mysql數(shù)據(jù)類型映射內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

