目录
  • protobuf中 float与double
  • 1、如何在rpc中优雅取出dcemial类型
  • 2、在rpc中 proto我们定义如下
    • 2.1、proto – double
    • 2.2、proto – float
  • 3、在go-zero的sqlx中生成的model

    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的操作方法

    声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。