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
結論: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ù)類型映射內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Go 并發(fā)實現(xiàn)協(xié)程同步的多種解決方法
這篇文章主要介紹了Go 并發(fā)——實現(xiàn)協(xié)程同步的多種解決方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-08-08
GoLang并發(fā)機制探究goroutine原理詳細講解
goroutine是Go語言提供的語言級別的輕量級線程,在我們需要使用并發(fā)時,我們只需要通過 go 關鍵字來開啟 goroutine 即可。這篇文章主要介紹了GoLang并發(fā)機制goroutine原理,感興趣的可以了解一下2022-12-12
go?module化?import?調用本地模塊?tidy的方法
這篇文章主要介紹了go?module化?import?調用本地模塊?tidy的相關知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09
Go語言驅動低代碼應用引擎工具Yao開發(fā)管理系統(tǒng)
這篇文章主要為大家介紹了Go語言驅動低代碼應用引擎工具Yao開發(fā)管理系統(tǒng)使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06

