脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Golang - GO将mysql 中 decimal 数据类型映射到 protobuf的操作方法

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

2022-11-23 10:20CTRA王大大 Golang

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

protobuf中 float与double

1、如何在rpc中优雅取出dcemial类型

例如我们在mysql中定义的一个字段如下:

?
1
`discount` decimal(10,2) NOT NULL DEFAULT '0.00' COMMENT '折扣',

2、在rpc中 proto我们定义如下

这里主要展示一下在 protobuf中 float与double的一个区别

2.1、proto - double

*.proto文件如下:

?
1
2
3
message Price {
  double discount = 1; // 折扣
}

我们来看一下定义为double生成的实体类为
通过go-zero直接生成的*_pb.go文件如下:

?
1
2
3
4
5
6
7
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文件如下:

?
1
2
3
message Price {
  float discount = 1; // 折扣
}

我们来看一下定义为double生成的实体类为
通过go-zero直接生成的*_pb.go文件如下:

?
1
2
3
4
5
6
7
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指令:

?
1
goctl model mysql datasource -url="root:123@tcp(127.0.0.1:3306)/数据库名" -table="xxx" -dir=./internal/model

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

到此这篇关于go如何优雅地将 mysql 中 decimal 数据类型映射到 protobuf的文章就介绍到这了,更多相关go mysql数据类型映射内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/wanglei19891210/article/details/127001552

延伸 · 阅读

精彩推荐
  • Golang浅谈goland导入自定义包时出错(一招解决问题)

    浅谈goland导入自定义包时出错(一招解决问题)

    这篇文章主要介绍了浅谈goland导入自定义包时出错(一招解决问题),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    不愿透露姓名的菜鸟28652021-02-26
  • GolangGo语言空结构体详解

    Go语言空结构体详解

    本文主要介绍了Go语言空结构体详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    漫漫Coding路9912022-08-31
  • Golang服务器端Go程序对长短链接的处理及运行参数的保存

    服务器端Go程序对长短链接的处理及运行参数的保存

    这篇文章主要介绍了服务器端Go程序对长短链接的处理及运行参数的保存,这里针对使用Go语言编写的Socket服务器进行实例说明,需要的朋友可以参考下 ...

    G1SLu2802020-04-29
  • Golanggo语言实现AES加密的方法

    go语言实现AES加密的方法

    这篇文章主要介绍了go语言实现AES加密的方法,实例分析了Go语言的加密技巧,需要的朋友可以参考下 ...

    dingding8012020-04-20
  • GolangGo语言中slice的用法实例分析

    Go语言中slice的用法实例分析

    这篇文章主要介绍了Go语言中slice的用法,实例分析了slice的功能及使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下 ...

    不是JS1892020-04-17
  • GolangGo中Writer和Reader接口的使用入门

    Go中Writer和Reader接口的使用入门

    本文主要介绍了Go中Writer和Reader接口的使用入门,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    宇宙之一粟11632022-09-25
  • Golangvscode搭建go开发环境案例详解

    vscode搭建go开发环境案例详解

    对于Visual Studio Code开发工具,有一款优秀的GoLang插件,今天通过本文给大家介绍下vscode搭建go开发环境的详细教程,感兴趣的朋友跟随小编一起看看吧 ...

    呆萌小新@渊洁6042022-01-24
  • GolangGo语言的type func()用法详解

    Go语言的type func()用法详解

    在Go语言中,函数的基本组成为:关键字func、函数名、参数列表、返回值、函数体和返回语句,这篇文章主要介绍了Go语言的type func()用法,需要的朋友可以...

    西京刀客7282022-09-08