go-pg:Golang的PostgreSQL ORM库
项目基础介绍和主要编程语言
go-pg是一个专注于PostgreSQL特性和性能的Golang ORM库。它提供了一个强大的工具集,帮助开发者更高效地与PostgreSQL数据库进行交互。该项目的主要编程语言是Go。
项目核心功能
go-pg的核心功能包括:
- 基本类型支持:支持整数、浮点数、字符串、布尔值、时间、IP地址等基本数据类型。
- JSON序列化:结构体、映射和数组默认以JSON格式进行序列化。
- 数组和Hstore支持:支持PostgreSQL的多维数组和Hstore类型。
- 复合类型支持:支持PostgreSQL的复合类型。
- 事务和预处理语句:支持事务处理和预处理语句。
- 通知机制:支持使用LISTEN和NOTIFY进行通知。
- 数据复制:支持使用COPY FROM和COPY TO进行数据复制。
- 上下文支持:支持使用context.Context进行超时和查询取消。
- 连接池和断路器:自动连接池管理,支持断路器模式。
- 重试机制:在网络错误时自动重试查询。
- ORM和SQL支持:支持使用ORM和SQL进行模型操作和变量扫描。
- 批量操作:支持批量插入、更新和删除。
- 常见表表达式:支持使用WITH和WrapWith进行常见表表达式操作。
- 估计行数:使用EXPLAIN获取匹配行的估计数量。
- 关系映射:支持一对一、一对多和多对多关系映射。
- 软删除:支持软删除功能。
- 表结构创建:支持从结构体创建数据库表。
- 逐行处理:支持逐行处理查询结果,避免内存溢出。
项目最近更新的功能
go-pg最近更新的功能包括:
- 维护模式:go-pg目前处于维护模式,仅处理关键问题。新开发功能转移到Bun项目中,Bun项目支持PostgreSQL、MySQL、MariaDB和SQLite。
- 新文档和示例:更新了文档和示例,包括monetr(预算应用程序)、bunrouter(HTTP路由器)、go-kit(微服务框架)等。
- 新教程:新增了GraphQL教程和现代API设计教程。
- 新工具:新增了Genna(CLI工具,用于生成go-pg模型)和bigint(大整数类型)。
- 新功能:新增了urlstruct(解码URL值到结构体)和Sharding(分片功能)。
- 新监控工具:新增了go-pg-monitor,基于go-pg客户端统计的Prometheus指标。