1.8类型

106 阅读2分钟

PostgreSQL有一组丰富的本机数据类型可供用户使用。用户可以使用 CREATE TYPE 命令向 PostgreSQL 添加新类型。

表 8.1 显示了所有内置的通用数据类型。“别名”列中列出的大多数替代名称都是PostgreSQL出于历史原因在内部使用的名称。此外,一些内部使用或已弃用的类型可用,但此处未列出。

表 8.1.数据类型

名字别名描述
bigintint8有符号八字节整数
bigserialserial8自动递增八字节整数
bit [ (n) ] 固定长度的位字符串
bit varying [ (n) ]varbit [ (n) ]可变长度位字符串
booleanbool逻辑布尔值(真/假)
box 平面上的矩形框
bytea 二进制数据(“字节数组”)
character [ (n) ]char [ (n) ]固定长度的字符串
character varying [ (n) ]varchar [ (n) ]可变长度字符串
cidr IPv4 或 IPv6 网络地址
circle 在飞机上转圈
date 日历日期(年、月、日)
double precisionfloat8双精度浮点数(8 字节)
inet IPv4 或 IPv6 主机地址
integerint,int4有符号四字节整数
interval [ fields ] [ (p) ] 时间跨度
json 文本 JSON 数据
jsonb 二进制 JSON 数据,已分解
line 平面上的无限线
lseg 平面上的线段
macaddr MAC(媒体访问控制)地址
macaddr8 MAC(媒体访问控制)地址(EUI-64 格式)
money 货币金额
numeric [ (p, s) ]decimal [ (p, s) ]可选精度的精确数字
path 平面上的几何路径
pg_lsn PostgreSQL日志序列号
point 平面上的几何点
polygon 平面上的闭合几何路径
realfloat4单精度浮点数(4 字节)
smallintint2有符号双字节整数
smallserialserial2自动递增双字节整数
serialserial4自动递增四字节整数
text 可变长度字符串
time [ (p) ] [ without time zone ] 一天中的时间(无时区)
time [ (p) ] with time zonetimetz一天中的时间,包括时区
timestamp [ (p) ] [ without time zone ] 日期和时间(无时区)
timestamp [ (p) ] with time zonetimestamptz日期和时间,包括时区
tsquery 文本搜索查询
tsvector 文本搜索文档
txid_snapshot 用户级交易 ID 快照
uuid 通用唯一标识符
xml XML 数据

兼容性

SQL指定以下类型(或其拼写):,,(带或不带时区),。bigint``bit``bit varying``boolean``char``character varying``character``varchar``date``double precision``integer``interval``numeric``decimal``real``smallint``time``timestamp``xml

每种数据类型都有一个由其输入和输出函数确定的外部表示形式。许多内置类型具有明显的外部格式。但是,有几种类型是 PostgreSQL 独有的,例如几何路径,或者具有几种可能的格式,例如日期和时间类型。一些输入和输出函数是不可逆的,即与原始输入相比,输出函数的结果可能会失去精度。