0

0

Go - 使用 pgtypes 的正确方法

PHPz

PHPz

发布时间:2024-02-13 22:18:10

|

1425人浏览过

|

来源于stackoverflow

转载

go - 使用 pgtypes 的正确方法

php小编西瓜今天为大家介绍一种正确的使用 pgtypes 的方法,这对于使用 Go 语言进行 PostgreSQL 数据库编程的开发者来说非常重要。pgtypes 是一个 Go 语言的库,它提供了与 PostgreSQL 数据库类型之间的转换和处理功能。正确使用 pgtypes 可以避免在处理数据库类型时出现错误和异常,同时也可以提高代码的可读性和可维护性。在本文中,我们将详细介绍如何正确使用 pgtypes,以及一些常见的注意事项和最佳实践。如果你是一名使用 Go 语言进行 PostgreSQL 数据库编程的开发者,那么请继续阅读下去,相信本文对你会有所帮助。

问题内容

我正在开发一个简单的 Go 服务来连接到数据库进行基本查询。我正在使用 sqlc 生成 Go 函数来与数据库交互。当将驱动程序从 lib/pq 切换到 pgx/v5 时,现在数据库字段的类型是 pgtypes 而不是 Go 类型。这是一个例子:

而不是这个:

type ListAccountsParams struct {
        Owner  string `json:"owner"`
        Limit  int32  `json:"limit"`
        Offset int32  `json:"offset"`
    }

我现在明白了:

type ListAccountsParams struct {
        Owner  pgtype.Text `json:"owner"`
        Limit  pgtype.Int4 `json:"limit"`
        Offset pgtype.Int4 `json:"offset"`
    }

但是我发现使用 pgtypes 的唯一方法是这个:

owner := pgtype.Text{
        String: "Craigs List",
        Valid: true,
    }

而不是仅仅执行 owner := "Craigs List"。对于数字类型就更矫枉过正了,我找到的所有实现都是这样的:

pgtype.Numeric{
    Int: big.NewInt(-543), 
    Exp: 3, 
    Status: pgtype.Present
    }

使用 sqlc 配置文件,我可以覆盖这些类型以支持 Go 标准类型,但是对我来说必须将 postgres text 类型覆盖为 string 等等是没有意义的...

非常淘 淘宝客源码
非常淘 淘宝客源码

本源码是我用过最好的淘客站源码。对于新站长很用帮助。重要!!注意上传完程序后要先登陆后台修改域名,否则会跳转到后台已设置的域名。 使用方法1:将文件夹里面的文件上传至您的空间根目录(不要在本地测试,本地测试期间功能将被限制,首页模板显示不正常!)2:访问网址http://您的网址/admin 账号:admin 密码:admin3:填写您基本网站信息,以及重要的淘客相关信息 声明:本程序使用权是本人

下载

在我看来,这不是使用这些类型的最佳方式,这对我来说是违反直觉的。所以我的问题是,我做得对吗?有不同的方法吗?最终,有没有办法配置 sqlc 使用 Go 类型而不是 pgtypes,同时仍然使用 pgx/v5 驱动程序?

解决方法

您可以编辑 sqlc 配置文件,为要使用 Go 类型而不是 pgtype 类型的字段指定自定义类型,并通过在 sqlc.yaml 文件中指定所需的 Go 类型来覆盖类型

types:
  - name: ListAccountsParams
    fields:
      - name: Owner
        goType: string
      - name: Limit
        goType: int32
      - name: Offset
        goType: int32

请注意,直接使用 Go 类型在与数据库交互时可能会导致潜在的类型不匹配或其他问题,而 pgtype 类型是专门为处理 PostgreSQL 特定的数据类型而设计的,并提供一定程度的类型安全性和兼容性!

更新

根据您的评论,当将 pgx/v5 驱动程序与 sqlc 一起使用时,生成的代码使用 pgtype 类型来处理 PostgreSQL 特定的数据类型,这是 sqlc 在使用 pgx/v5 驱动程序时的默认行为,以及方式您描述的使用 pgtype 类型,例如 pgtype.Textpgtype.Int4,是处理这些类型的正确方法,例如,在处理 pgtype.Text 类型时,您需要将 String 字段设置为所需的值,并将 Valid 字段设置为 true

对于数字类型,pgtype.Numeric类型需要设置IntExpStatus字段,这是因为pgtype.Numeric类型表示一个任意精度整数的数值(Int) ), 指数(Exp),以及一个状态(Status),指示该值是否存在或为空!

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

309

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

463

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

463

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

544

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

93

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

200

2025.08.29

postgresql常用命令
postgresql常用命令

postgresql常用命令psql、createdb、dropdb、createuser、dropuser、l、c、dt、d table_name、du、i file_name、e和q等。本专题为大家提供postgresql相关的文章、下载、课程内容,供大家免费下载体验。

158

2023.10.10

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号