当前位置: 首页 > news >正文

【PostgreSQL 】入门篇——支持的各种数据类型介绍,包括整数、浮点数、字符串、日期、JSON、数组等

1. 整数类型

1.1 SMALLINT

  • 描述:用于存储小范围的整数值。
  • 大小:2 字节
  • 范围:-32,768 到 32,767
  • 使用场景:适合存储小型计数器、状态码等。
  • 示例
CREATE TABLE status_codes (id SMALLINT PRIMARY KEY,description TEXT
);

1.2 INTEGER

  • 描述:用于存储中等范围的整数值。
  • 大小:4 字节
  • 范围:-2,147,483,648 到 2,147,483,647
  • 使用场景:常用于存储用户 ID、订单 ID 等。
  • 示例
CREATE TABLE users (user_id INTEGER PRIMARY KEY,username VARCHAR(50)
);

1.3 BIGINT

  • 描述:用于存储大型整数值。
  • 大小:8 字节
  • 范围:-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807
  • 使用场景:适合存储大数据分析中的行数、全局唯一标识符(UUID)等。
  • 示例
CREATE TABLE large_data (record_id BIGINT PRIMARY KEY,value NUMERIC
);

2. 浮点数类型

2.1 REAL

  • 描述:用于存储单精度浮点数。
  • 大小:4 字节
  • 范围:-3.40282347E+38 到 3.40282347E+38
  • 使用场景:适合需要节省存储空间的应用,如图形处理、科学计算等。
  • 示例
CREATE TABLE measurements (id SERIAL PRIMARY KEY,temperature REAL
);

2.2 DOUBLE PRECISION

  • 描述:用于存储双精度浮点数。
  • 大小:8 字节
  • 范围:-1.7976931348623157E+308 到 1.7976931348623157E+308
  • 使用场景:适合需要高精度的计算,如金融应用、统计分析等。
  • 示例
CREATE TABLE financial_data (transaction_id SERIAL PRIMARY KEY,amount DOUBLE PRECISION
);

2.3 NUMERIC

  • 描述:用于存储高精度的数字。
  • 大小:可变长度
  • 范围:可指定精度和小数位数
  • 使用场景:适合存储货币、精确的科学计算等。
  • 示例
CREATE TABLE products (product_id SERIAL PRIMARY KEY,price NUMERIC(10, 2)  -- 10 位数字,其中 2 位为小数
);

3. 字符串类型

3.1 CHAR(n)

  • 描述:用于存储固定长度的字符串。
  • 大小:固定长度
  • 使用场景:适合存储国家代码、邮政编码等。
  • 示例
CREATE TABLE countries (country_code CHAR(2) PRIMARY KEY,country_name VARCHAR(100)
);

3.2 VARCHAR(n)

  • 描述:用于存储可变长度的字符串。
  • 大小:可变长度,最大长度为 n
  • 使用场景:适合存储用户名、电子邮件地址等。
  • 示例
CREATE TABLE users (user_id SERIAL PRIMARY KEY,email VARCHAR(255) UNIQUE
);

3.3 TEXT

  • 描述:用于存储大量文本数据。
  • 大小:可变长度,最大可达 1 GB
  • 使用场景:适合存储文章内容、用户评论等。
  • 示例
CREATE TABLE articles (article_id SERIAL PRIMARY KEY,content TEXT
);

4. 日期和时间类型

4.1 DATE

  • 描述:用于存储日期信息。
  • 大小:4 字节
  • 范围:4713 BC 到 5874897 AD
  • 使用场景:适合存储出生日期、事件日期等。
  • 示例
CREATE TABLE events (event_id SERIAL PRIMARY KEY,event_date DATE
);

4.2 TIME

  • 描述:用于存储时间信息。
  • 大小:8 字节
  • 范围:00:00:00 到 24:00:00
  • 使用场景:适合存储工作时间、事件发生时间等。
  • 示例
CREATE TABLE schedules (schedule_id SERIAL PRIMARY KEY,start_time TIME
);

4.3 TIMESTAMP

  • 描述:用于存储日期和时间的组合。
  • 大小:8 字节
  • 范围:4713 BC 到 5874897 AD
  • 使用场景:适合存储记录创建时间、订单时间等。
  • 示例
CREATE TABLE orders (order_id SERIAL PRIMARY KEY,order_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

4.4 INTERVAL

  • 描述:用于表示两个时间点之间的时间间隔。
  • 大小:可变长度
  • 使用场景:适合存储活动持续时间、事件间隔等。
  • 示例
CREATE TABLE tasks (task_id SERIAL PRIMARY KEY,duration INTERVAL
);

5. JSON 类型

5.1 JSON

  • 描述:用于存储非结构化数据,支持 JSON 格式。
  • 大小:可变长度
  • 使用场景:适合存储配置文件、用户偏好设置等。
  • 示例
CREATE TABLE settings (user_id SERIAL PRIMARY KEY,preferences JSON
);

5.2 JSONB

  • 描述:与 JSON 类似,但以二进制格式存储。
  • 大小:可变长度
  • 使用场景:适合需要频繁查询和修改 JSON 数据的场景。
  • 示例
CREATE TABLE user_profiles (user_id SERIAL PRIMARY KEY,profile_data JSONB
);

6. 数组类型

6.1 数组

  • 描述:用于存储同一类型的多个值。
  • 大小:可变长度
  • 使用场景:适合存储用户的多个电话号码、订单中的多个商品等。
  • 示例
CREATE TABLE contacts (user_id SERIAL PRIMARY KEY,phone_numbers TEXT[]
);

7. 其他数据类型

7.1 UUID

  • 描述:用于存储全球唯一标识符。
  • 大小:16 字节
  • 使用场景:适合存储用户 ID、订单 ID 等,避免 ID 冲突。
  • 示例
CREATE TABLE sessions (session_id UUID PRIMARY KEY DEFAULT gen_random_uuid(),user_id INTEGER
);

7.2 XML

  • 描述:用于存储 XML 格式的数据。
  • 大小:可变长度
  • 使用场景:适合存储配置文件、数据交换等。
  • 示例
CREATE TABLE xml_data (id SERIAL PRIMARY KEY,data XML
);

7.3 BYTEA

  • 描述:用于存储二进制数据。
  • 大小:可变长度
  • 使用场景:适合存储图像、音频、视频文件等。
  • 示例
CREATE TABLE media (media_id SERIAL PRIMARY KEY,file_data BYTEA
);

7.4 TSVECTOR 和 TSQUERY

  • 描述:用于支持全文搜索的文本数据类型。
  • 使用场景:适合存储和查询文本搜索相关的数据。
  • 示例
CREATE TABLE documents (doc_id SERIAL PRIMARY KEY,content TEXT,search_vector TSVECTOR
);

8. 总结

PostgreSQL 提供了丰富的数据类型,以满足不同应用场景的需求。

选择合适的数据类型可以提高数据库的性能和存储效率。

在设计数据库时,应根据实际需求合理选择数据类型,以便于后续的数据操作和维护。

希望以上内容能帮助您更好地理解 PostgreSQL 支持的数据类型及其使用场景。

http://www.lryc.cn/news/451922.html

相关文章:

  • 野火STM32F103VET6指南者开发板入门笔记:【1】点亮RGB
  • 数据工程师岗位常见面试问题-3(附回答)
  • 强大的JVM监控工具
  • python 实现点的多项式算法
  • Pikachu-暴力破解-验证码绕过(on client)
  • 【Spring】Bean 的生命周期:从实例化到销毁
  • Ubuntu 安装RUST
  • Android Compose的基本使用
  • 计算机网络:计算机网络体系结构 —— 专用术语总结
  • Rust的前端Tauri编程-基于JS框架的初步探索
  • 【Flume Kafaka实战】Using Kafka with Flume
  • 5G NR物理信号
  • Pikachu-Cross-Site Scripting-存储型xss
  • 媲美GPT-4o mini的小模型,Meta Llama 3.2模型全面解读!
  • 【leetcode】 45.跳跃游戏 ||
  • coco(json)、yolo(txt)、voc(xml)标注格式的相互转换
  • 以太网交换安全:端口安全
  • [题解] Codeforces Round 976 (Div. 2) A ~ E
  • 【零基础入门产品经理】学习准备篇 | 需要学一些什么呢?
  • 第四届机器人、自动化与智能控制国际会议(ICRAIC 2024)征稿
  • [数据集][目标检测]电力场景防震锤缺陷检测数据集VOC+YOLO格式705张1类别
  • 【SpringBoot】
  • Linux操作系统中MongoDB
  • 2、.Net 前端框架:OpenAuth.Net - .Net宣传系列文章
  • unreal engine5制作动作类游戏时,我们使用刀剑等武器攻击怪物或敌方单位时,发现攻击特效、伤害等没有触发
  • 数据权限的设计与实现系列11——前端筛选器组件Everright-filter集成功能完善2
  • C++ 游戏开发
  • 【历年CSP-S复赛第一题】暴力解法与正解合集(2019-2022)
  • 基于PyQt5和SQLite的数据库操作程序
  • 在Ubuntu 20.04中安装CARLA