• PostgreSQL 数据类型详细说明


    PostgreSQL 提供了多种数据类型,每种数据类型都有其特定的应用场景、数据类型范围以及使用禁忌。以下是一些常见的数据类型及其相关信息:

    1. 数值类型:

      • SMALLINT: 范围是 -32768 到 32767。适用于小范围的整数数据,如年龄、数量。
      • INTEGER: 范围是 -2147483648 到 2147483647。适用于中等范围的整数数据,如用户数量、商品库存。
      • BIGINT: 范围是 -9223372036854775808 到 9223372036854775807。适用于大范围的整数数据,如大型数据库的行数、网络流量统计。
      • DECIMAL: 精度可变的小数类型,用于存储精确的小数,如金融交易中的货币金额。
      • NUMERIC: 同 DECIMAL,用于存储精确的小数。
      • REAL: 单精度浮点数,范围约为 ±1.7e-308 到 ±1.7e+308。适用于科学计算、图形处理等对精度要求不高的场景。
      • DOUBLE PRECISION: 双精度浮点数,范围约为 ±2.2e-308 到 ±1.8e+308。适用于需要更高精度的科学计算和图形处理。
      • 使用禁忌:避免使用数值类型存储非数值数据,如电话号码(应使用字符类型)。避免使用浮点数进行货币计算,因为它们可能会导致精度损失。
    2. 字符类型:

      • CHAR(n): 固定长度的字符串,最大长度为 n。适用于长度固定的数据,如邮政编码、缩写。
      • VARCHAR(n): 可变长度的字符串,最大长度为 n。适用于长度可变的数据,如电子邮件地址、用户名。
      • TEXT: 可变长度的字符串,没有长度限制。适用于长文本数据,如文章内容、评论。
      • 使用禁忌:避免使用 VARCHAR 或 TEXT 存储大量二进制数据,应使用 BYTEA。避免使用 CHAR 类型存储长度可变的数据,因为这可能会导致空间浪费。
    3. 日期/时间类型:

      • DATE: 范围是 4713 BC 到 5874897 AD。适用于仅存储日期的数据,如生日、节假日。
      • TIME: 范围是 00:00:00 到 24:00:00。适用于仅存储时间的数据,如会议时长、工作时间。
      • TIMESTAMP: 范围是 4713 BC 到 294276 AD。适用于存储日期和时间的数据,如用户的注册时间、帖子的发布时间。
      • TIMESTAMPTZ: 带时区的 TIMESTAMP,适用于存储带时区的日期和时间的数据。
      • INTERVAL: 用于存储时间间隔,如日程安排、活动持续时间。
      • 使用禁忌:避免使用日期/时间类型存储非日期时间数据,如人的姓名。避免使用 TIMESTAMP 存储仅日期或仅时间的数据,因为这可能会导致不必要的时区处理。
    4. 布尔类型:

      • BOOLEAN: 用于存储真/假值。
      • 使用禁忌:避免使用布尔类型存储多种状态,应使用枚举类型或整数类型。
    5. JSON/JSONB 类型:

      • JSONJSONB: 用于存储结构化数据,如用户的配置信息、文章的元数据。
      • 使用禁忌:避免使用 JSON 类型存储关键的业务逻辑数据,因为这可能导致数据查询和操作复杂化。避免在 JSONB 类型中使用复杂的数据结构,因为它们可能会导致性能问题。
    6. 几何类型:

      • POINT: 用于存储地理位置点,如用户的当前位置。
      • POLYGON: 用于存储多边形区域,如地图上的兴趣区域。
      • 使用禁忌:避免使用几何类型存储非空间数据,如文本描述。
    7. 网络地址类型:

      • INET: 用于存储 IP 地址和子网,如网络设备的 IP 地址。
      • 使用禁忌:避免使用网络地址类型存储非网络相关的数据,如人的姓名。
    8. UUID 类型:

      • UUID: 用于存储全局唯一的标识符,如数据库记录的唯一标识。
      • 使用禁忌:避免使用 UUID 类型存储短字符串标识,因为这会增加存储空间和索引的大小。

    选择合适的数据类型对于数据库的性能、存储效率和数据完整性至关重要。在设计数据库时,应该根据实际的应用需求和数据特性来选择最合适的数据类型,并遵循使用禁忌以避免潜在的问题。

  • 相关阅读:
    Java的类中属性的使用
    【MySQL技术专题】「索引技术」体验前所未有的技术探险,看穿索引的本质和技术体系(1)
    基于 gin + websocket 即时通讯项目 (一、项目初始化)
    Lambda表达式,Stream流
    uniapp 如何发送formData数据请求(全网最佳解决方案)
    Java程序设计入门教程--Java语言概述
    架构师之路:中台和微服务区别
    Java小白必会!Intellij IDEA安装、配置及使用详细教程
    后仿真中的 《specify/endspecify block》之(5)使用specify进行时序仿真
    ChatGPT调教指南 | 咒语指南 | Prompts提示词教程(三)
  • 原文地址:https://blog.csdn.net/qq_40660389/article/details/139645874