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

目录
  • 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的文章就介绍到这了,更多相关go mysql数据类型映射内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Golang 处理浮点数遇到的精度问题(使用decimal)

    目录 一.浮点数是什么? 1.指数方案 2.规范化指数形式 3.IEEE754标准 二.出现精度问题的情况 1.浮点数加减运算 2.float64与float32之间转换 3.int64和float64,int32和float32转换 4.float64位直接乘100 三.decimal解决精度问题 1.浮点数加减运算 2.float64与float32之间转换 3.float64位直接乘100 总结 一.浮点数是什么? 浮点数,是属于有理数中某特定子集的数的数字表示,在计算机中用以近似表示任意

  • go语言中decimal的用法详解

    目录 1. 精度丢失的case 2. decimal的应用场景 3. 使用decimal 4. decimal其他实用的场景 4.1 获取结果的整数部分 4.2 小数点后填充 4.3 比较数字的大小 5 小结 decimal是为了解决Golang中浮点数计算时精度丢失问题而生的一个库,使用decimal库我们可以避免在go中使用浮点数出现精度丢失的问题. github地址:https://github.com/shopspring/decimal 1. 精度丢失的case func TestFl

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

    目录 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' CO

  • mysql中decimal数据类型小数位填充问题详解

    前言 在开发过程中,我们往往会用到decimal数据类型.因为decimal是MySQL中存在的精准数据类型. MySQL中的数据类型有:float,double等非精准数据类型和decimal这种精准. 区别:float,double等非精准类型,在DB中保存的是近似值. Decimal则以字符串的形式保存精确的原始数值. decimal介绍: decimal(a,b) 其中:a指定指定小数点左边和右边可以存储的十进制数字的最大个数,最大精度38.b指定小数点右边可以存储的十进制数字的最大个数

  • MySQL中Decimal类型和Float Double的区别(详解)

    MySQL中存在float,double等非标准数据类型,也有decimal这种标准数据类型. 其区别在于,float,double等非标准类型,在DB中保存的是近似值,而Decimal则以字符串的形式保存数值. float,double类型是可以存浮点数(即小数类型),但是float有个坏处,当你给定的数据是整数的时候,那么它就以整数给你处理.这样我们在存取货币值的时候自然遇到问题,我的default值为:0.00而实际存储是0,同样我存取货币为12.00,实际存储是12. 幸好mysql提供

  • mysql中整数数据类型tinyint详解

    目录 1.1 tinyint类型说明 1.2 实践环境说明 1.3 加unsigned属性 1.3.1 SQL模式开启严格模式 1.3.2 SQL模式未开启严格模式 1.4 加zerofill属性 1.4.1 SQL模式开启严格模式 1.4.2 SQL模式未开启严格模式 1.5 不加unsigned和zerofill属性 1.5.1 SQL模式开启严格模式 1.5.2 SQL模式未开启严格模式 1.1 tinyint类型说明 数据类型 显示长度 占用字节 有符号 无符号 tinyint 加上un

  • MySQL中BIGINT数据类型如何存储整数值

    目录 前言 MySQL BIGINT 例子 示例 1 示例 2 示例 3 示例 4 结论 前言 本文重点介绍 MySQL BIGINT 数据类型,并研究我们如何使用它来存储整数值.我们还将了解它的范围.存储大小和各种属性,包括有符号.无符号和零填充. 整数类型(精确值) - INTEGER.INT.SMALLINT.TINYINT.MEDIUMINT.BIGINT MySQL 支持 SQL 标准整数类型 INTEGER(或INT)和 SMALLINT. 作为标准的扩展,MySQL 还支持整数类型

  • MySQL中decimal类型用法的简单介绍

    MySQL中支持浮点数的类型有FLOAT.DOUBLE和DECIMAL类型,DECIMAL 类型不同于FLOAT和DOUBLE,DECIMAL 实际是以串存放的.DECIMAL 可能的最大取值范围与DOUBLE 一样,但是其有效的取值范围由M 和D 的值决定.如果改变M 而固定D,则其取值范围将随M 的变大而变大. 对于精度比较高的东西,比如money,建议使用decimal类型,不要考虑float,double, 因为他们容易产生误差,numeric和decimal同义,numeric将自动转

  • 设置MySQL中的数据类型来优化运行速度的实例

    今天看了一个优化案例觉的挺有代表性,这里记录下来做一个标记,来纪念一下随便的字段定义的问题. 回忆一下,在表的设计中很多人习惯的把表的结构设计成Varchar(64),Varchar(255)之类的,虽然大多数情况只存了5-15个字节.那么我看一下下面这个案例. 查询语句: SELECT SQL_NO_CACHE channel, COUNT(channel) AS visitors FROM xxx_sources WHERE client_id = 1301 GROUP BY client_

  • MySQL中的数据类型binary和varbinary详解

    前言 BINARY和VARBINARY与 CHAR和VARCHAR类型有点类似,不同的是BINARY和VARBINARY存储的是二进制的字符串,而非字符型字符串.也就是说,BINARY和VARBINARY没有字符集的概念,对其排序和比较都是按照二进制值进行对比. BINARY(N)和VARBINARY(N)中的N指的是字节长度,而CHAR(N)和VARCHAR(N)中N指的是的字符长度.对于BINARY(10) ,其可存储的字节固定为10,而对于CHAR(10) ,其可存储的字节视字符集的情况而

  • MySQL中int (10) 和 int (11) 的区别

    mysql 中整数数据类型: 不同类型的取值范围: 不同数据类型的默认v显示宽度: 显示的宽度跟负号没有关系,它只在人工设置了 ZEROFILL 属性有效.一旦人工设置了 ZEROFILL 属性,MySQL 会自动设置 UNSIGNED 属性(即 ZEROFILL 不能存储负数). 那取值范围和显示宽度到底有什么关系呢?利用 tinyint 做了个实验, 首先创建一张表如下: mysql> desc test_integer; +-----------+------------+------+-

  • MySQL数据类型中DECIMAL的用法实例详解

    MySQL数据类型中DECIMAL的用法实例详解 在MySQL数据类型中,例如INT,FLOAT,DOUBLE,CHAR,DECIMAL等,它们都有各自的作用,下面我们就主要来介绍一下MySQL数据类型中的DECIMAL类型的作用和用法. 一般赋予浮点列的值被四舍五入到这个列所指定的十进制数.如果在一个FLOAT(8, 1)的列中存储1. 2 3 4 5 6,则结果为1. 2.如果将相同的值存入FLOAT(8, 4) 的列中,则结果为1. 2 3 4 6. 这表示应该定义具有足够位数的浮点列以便

随机推荐