PostgreSQL有一组丰富的本机数据类型可供用户使用。用户可以使用 CREATE TYPE 命令向 PostgreSQL 添加新类型。
表 8.1 显示了所有内置的通用数据类型。“别名”列中列出的大多数替代名称都是PostgreSQL出于历史原因在内部使用的名称。此外,一些内部使用或已弃用的类型可用,但此处未列出。
表 8.1.数据类型
| 名字 | 别名 | 描述 |
|---|---|---|
bigint | int8 | 有符号八字节整数 |
bigserial | serial8 | 自动递增八字节整数 |
bit [ (n) ] | 固定长度的位字符串 | |
bit varying [ (n) ] | varbit [ (n) ] | 可变长度位字符串 |
boolean | bool | 逻辑布尔值(真/假) |
box | 平面上的矩形框 | |
bytea | 二进制数据(“字节数组”) | |
character [ (n) ] | char [ (n) ] | 固定长度的字符串 |
character varying [ (n) ] | varchar [ (n) ] | 可变长度字符串 |
cidr | IPv4 或 IPv6 网络地址 | |
circle | 在飞机上转圈 | |
date | 日历日期(年、月、日) | |
double precision | float8 | 双精度浮点数(8 字节) |
inet | IPv4 或 IPv6 主机地址 | |
integer | int,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 | 平面上的闭合几何路径 | |
real | float4 | 单精度浮点数(4 字节) |
smallint | int2 | 有符号双字节整数 |
smallserial | serial2 | 自动递增双字节整数 |
serial | serial4 | 自动递增四字节整数 |
text | 可变长度字符串 | |
time [ (p) ] [ without time zone ] | 一天中的时间(无时区) | |
time [ (p) ] with time zone | timetz | 一天中的时间,包括时区 |
timestamp [ (p) ] [ without time zone ] | 日期和时间(无时区) | |
timestamp [ (p) ] with time zone | timestamptz | 日期和时间,包括时区 |
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 独有的,例如几何路径,或者具有几种可能的格式,例如日期和时间类型。一些输入和输出函数是不可逆的,即与原始输入相比,输出函数的结果可能会失去精度。