0

0

postgresqlrange类型如何存储区间数据_postgresql区间类型解析

舞姬之光

舞姬之光

发布时间:2025-12-02 22:01:02

|

580人浏览过

|

来源于php中文网

原创

postgresql常用range类型包括int4range、int8range、numrange、tsrange、tstzrange和daterange,适用于不同数据类型的区间存储;可通过内置构造函数或文本格式插入数据,支持包含、重叠、左侧等丰富操作符,并可结合gist索引高效查询,还允许自定义如floatrange等新类型,广泛用于时间范围、数值区间等场景。

postgresqlrange类型如何存储区间数据_postgresql区间类型解析

PostgreSQL 的 range 类型 是一种专门用于表示值的区间的数据类型,非常适合存储如时间范围、数值区间等连续数据。它让区间操作变得高效且语义清晰,避免了手动维护起始和结束字段的复杂性。

常用 range 类型有哪些?

PostgreSQL 内置了几种常用的区间类型,对应不同的基础数据类型:

  • int4range:32位整数区间,例如价格范围、年龄区间
  • int8range:64位整数区间
  • numrange:任意精度数值(numeric)区间,适合金额等高精度场景
  • tsrange:不带时区的时间戳区间,常用于时间段记录
  • tstzrange:带时区的时间戳区间,推荐用于分布式系统
  • daterange:日期类型的区间
例如:[2024-01-01, 2024-01-31] 表示一整个月的日期范围,包含首尾。

如何定义和插入区间数据?

可以在建表时直接使用 range 类型字段:

CREATE TABLE reservations (
  id serial PRIMARY KEY,
  room_number int,
  period tstzrange
);

插入区间数据时,可以使用内置函数 range constructor 或文本格式:

INSERT INTO reservations (room_number, period)
VALUES 
  (101, '[2024-06-01 09:00, 2024-06-01 17:00)'),
  (102, tstzrange('2024-06-02 10:00', '2024-06-02 18:00', '[)'));
注意括号含义:
[ 表示包含端点,
) 表示不包含端点。
默认是左闭右开 [),可根据需要调整。

支持哪些区间操作?

range 类型提供丰富的操作符和函数,便于查询和判断:

Jaaz
Jaaz

开源的AI设计智能体

下载
  • @>:是否包含某个值或区间
    period @> '2024-06-01 12:00'::timestamptz
  • :是否被包含
  • &&:是否重叠
    period && '[2024-06-01 10:00, 2024-06-01 12:00)'
  • :是否完全在左侧(不重叠)
  • +:合并两个重叠或相邻的区间
  • lower()upper():获取区间的下界和上界

结合 GIST 或 SP-GIST 索引,这些操作能高效执行:

CREATE INDEX idx_reservations_period ON reservations USING gist (period);

自定义 range 类型(可选进阶)

如果内置类型不够用,比如想为 float 创建区间,可通过 CREATE TYPE 定义:

CREATE TYPE floatrange AS RANGE (
  subtype = double precision,
  subtype_diff = float8mi
);

注意:必须指定 subtype_diff 以支持长度估算,这对索引性能很重要。

基本上就这些。合理使用 range 类型能让区间逻辑更清晰,查询更安全,还能借助索引提升性能,特别适合排班、预订、有效期管理等场景。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

404

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.10.07

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

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

336

2023.10.31

php数据类型
php数据类型

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

224

2025.10.31

c语言 数据类型
c语言 数据类型

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

138

2026.02.12

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

594

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

105

2025.10.23

postgresql常用命令
postgresql常用命令

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

164

2023.10.10

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MongoDB 教程
MongoDB 教程

共17课时 | 3.2万人学习

XML教程
XML教程

共142课时 | 8.1万人学习

进程与SOCKET
进程与SOCKET

共6课时 | 0.4万人学习

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

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