百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

详解PostgreSQL数据类型 postgresql 数据类型

liebian365 2024-11-05 11:44 17 浏览 0 评论

字符类型

char(n), varchar(n) 和text。

char和varchar超出长度的字符都是空白,这种情况下该字串将被截断为最大长度。

如果没有长度声明,char等于char(1),而varchar则可以接受任何长度的字串。

数字类型

由2、4或8字节的整数以及4或8字节的浮点数和可选精度小数组成。

名字

存储尺寸

描述

范围

smallint

2字节

小范围整数

-32768 to +32767

integer

4字节

整数的典型选择

-2147483648 to +2147483647

bigint

8字节

大范围整数

-9223372036854775808 to +9223372036854775807

decimal

可变

用户指定精度,精确

最高小数点前131072位,以及小数点后16383位

numeric

可变

用户指定精度,精确

最高小数点前131072位,以及小数点后16383位

real

4字节

可变精度,不精确

6位十进制精度

double precision

8字节

可变精度,不精确

15位十进制精度

smallserial

2字节

自动增加的小整数

1到32767

serial

4字节

自动增加的整数

1到2147483647

bigserial

8字节

自动增长的大整数

1到9223372036854775807

serial:自增的int类型,自动创建了一个序列,把默认的值赋予下一个序列。当insert没有指定serial列的值时,则默认的从序列中取出值,并且将序列的值自动加1。

日期类型

名字

存储尺寸

描述

最小值

最大值

解析度

timestamp [ (p)][withouttimezone]

8字节

包括日期和时间(无时区)

4713 BC

294276 AD

1微秒 / 14位

timestamp [ (p)]withtimezone

8字节

包括日期和时间,有时区

4713 BC

294276 AD

1微秒 / 14位

date

4字节

日期(没有一天中的时间)

4713 BC

5874897 AD

1日

time [ (p)][withouttimezone]

8字节

一天中的时间(无日期)

0:00:00

24:00:00

1微秒 / 14位

time [ (p)]withtimezone

12字节

仅仅是一天中的时间,带有时区

00:00:00+1459

24:00:00-1459

1微秒 / 14位

interval [ fields][(p)]

16字节

时间间隔

-178000000年

178000000年

1微秒 / 14位

枚举(enum)类型

是由一个静态值的有序集合构成的数据类型,它们等效于很多编程语言所支持的enum类型。

枚举类型的一个例子可以是一周中的日期,或者一个数据的状态值集合。

枚举类型可以使用CREATE TYPE命令创建。

一旦被创建,枚举类型可以像很多其他类型一样在表和函数定义中使用。

一个枚举类型的值的排序是该类型被创建时所列出的值的顺序。

几何类型

名字

存储尺寸

表示

描述

point

16字节

平面上的点

(x,y)

line

32字节

无限长的线

{A,B,C}

lseg

32字节

有限线段

((x1,y1),(x2,y2))

box

32字节

矩形框

((x1,y1),(x2,y2))

path

16+16n字节

封闭路径(类似于多边形)

((x1,y1),...)

path

16+16n字节

开放路径

[(x1,y1),...]

polygon

40+16n字节

多边形(类似于封闭路径)

((x1,y1),...)

circle

24字节

<(x,y),r> (center point and radius)

网络地址类型

名字

存储尺寸

描述

cidr

7或19字节

IPv4和IPv6网络

inet

7或19字节

IPv4和IPv6主机以及网络

macaddr

6字节

MAC地址

位串类型

位串就是一串1和0的字串,可以用于存储和视觉化位掩码。

有两种类型的SQL位类型:bit(n)和bit varying(n); n是一个正整数。

  • bit类型的数据必须准确匹配长度n; 试图存储短些或者长一些的数据都是错误的。
  • 类型bit varying数据是最长n的变长类型;更长的串会被拒绝。
  • 写一个没有长度的bit等效于bit(1),没有长度的bit varying相当于没有长度限制。

数组类型

1、任何基本类型 (不是组合类型或域) 可以用作数组,只要在类型后面加一个中括号 ([]) 。

创建一个二维数组如下:

CREATE TABLE a(a int[][5]);

PG不强制要求定义数组大小,甚至维数也可以不定义。所有的数组作为type[].

ANSI 语法只支持一维数组,并且需要定义数组大小:

CREATE TABLE a(a int ARRAY[5]);

Arrays 可以为 NULL, 但数组内的元素不能为null。

2、不限长度:int[]和int[10]都不会限定元素个数。

不限维度:int[]和int[][]效果是一样的,都可以存储任意维度的数组。

矩阵强制:多维数组中,同一个维度的元素个数必须相同。

元素强制:元素类型必须一致。

3、扩展:

  • 一维数组支持prepend(往前追加),append(往后追加),cat(两个数组合并)操作。
  • 二维数组仅支持cat操作:array_append、array_prepend、array_cat。
  • subscript:数组的下标,默认是从1开始编号,除非赋值的时候强制指定subscript。

文本搜索类型

PostgreSQL提供两种数据类型,它们被设计用来支持全文搜索。

  • tsvector类型:表示一个为文本搜索优化的形式下的文档,去除重复分词后按分词顺序存储可以存储位置信息和权重信息。
  • tsquery类型:表示一个文本查询,存储查询的分词,可存储权重信息。

XML类型

XML数据类型可以被用来存储XML数据。

XML数据类型比直接在一个text域中存储XML数据的优势在于:

  • 会检查输入值的结构是不是良好;
  • 有支持函数用于在其上执行类型安全的操作。

使用这种数据类型要求在安装时用configure --with-libxml选项编译。


墨天轮原文链接:https://www.modb.pro/db/150306?sjhy(复制链接至浏览器或点击文末阅读原文查看)

关于作者

陈家睿,云和恩墨MySQL技术顾问,拥有MySQL OCP、PGCE、OBCA、SCDP证书,长期服务于电信行业。现负责公司MySQL数据库、分布式数据库运维方面的技术工作;热衷于运维故障处理、备份恢复、升级迁移、性能优化的学习与分享。

相关推荐

4万多吨豪华游轮遇险 竟是因为这个原因……

(观察者网讯)4.7万吨豪华游轮搁浅,竟是因为油量太低?据观察者网此前报道,挪威游轮“维京天空”号上周六(23日)在挪威近海发生引擎故障搁浅。船上载有1300多人,其中28人受伤住院。经过数天的调...

“菜鸟黑客”必用兵器之“渗透测试篇二”

"菜鸟黑客"必用兵器之"渗透测试篇二"上篇文章主要针对伙伴们对"渗透测试"应该如何学习?"渗透测试"的基本流程?本篇文章继续上次的分享,接着介绍一下黑客们常用的渗透测试工具有哪些?以及用实验环境让大家...

科幻春晚丨《震动羽翼说“Hello”》两万年星间飞行,探测器对地球的最终告白

作者|藤井太洋译者|祝力新【编者按】2021年科幻春晚的最后一篇小说,来自大家喜爱的日本科幻作家藤井太洋。小说将视角放在一颗太空探测器上,延续了他一贯的浪漫风格。...

麦子陪你做作业(二):KEGG通路数据库的正确打开姿势

作者:麦子KEGG是通路数据库中最庞大的,涵盖基因组网络信息,主要注释基因的功能和调控关系。当我们选到了合适的候选分子,单变量研究也已做完,接着研究机制的时便可使用到它。你需要了解你的分子目前已有哪些...

知存科技王绍迪:突破存储墙瓶颈,详解存算一体架构优势

智东西(公众号:zhidxcom)编辑|韦世玮智东西6月5日消息,近日,在落幕不久的GTIC2021嵌入式AI创新峰会上,知存科技CEO王绍迪博士以《存算一体AI芯片:AIoT设备的算力新选择》...

每日新闻播报(September 14)_每日新闻播报英文

AnOscarstatuestandscoveredwithplasticduringpreparationsleadinguptothe87thAcademyAward...

香港新巴城巴开放实时到站数据 供科技界研发使用

中新网3月22日电据香港《明报》报道,香港特区政府致力推动智慧城市,鼓励公私营机构开放数据,以便科技界研发使用。香港运输署21日与新巴及城巴(两巴)公司签署谅解备忘录,两巴将于2019年第3季度,开...

5款不容错过的APP: Red Bull Alert,Flipagram,WifiMapper

本周有不少非常出色的app推出,鸵鸟电台做了一个小合集。亮相本周榜单的有WifiMapper's安卓版的app,其中包含了RedBull的一款新型闹钟,还有一款可爱的怪物主题益智游戏。一起来看看我...

Qt动画效果展示_qt显示图片

今天在这篇博文中,主要实践Qt动画,做一个实例来讲解Qt动画使用,其界面如下图所示(由于没有录制为gif动画图片,所以请各位下载查看效果):该程序使用应用程序单窗口,主窗口继承于QMainWindow...

如何从0到1设计实现一门自己的脚本语言

作者:dong...

三年级语文上册 仿写句子 需要的直接下载打印吧

描写秋天的好句好段1.秋天来了,山野变成了美丽的图画。苹果露出红红的脸庞,梨树挂起金黄的灯笼,高粱举起了燃烧的火把。大雁在天空一会儿写“人”字,一会儿写“一”字。2.花园里,菊花争奇斗艳,红的似火,粉...

C++|那些一看就很简洁、优雅、经典的小代码段

目录0等概率随机洗牌:1大小写转换2字符串复制...

二年级上册语文必考句子仿写,家长打印,孩子照着练

二年级上册语文必考句子仿写,家长打印,孩子照着练。具体如下:...

一年级语文上 句子专项练习(可打印)

...

亲自上阵!C++ 大佬深度“剧透”:C++26 将如何在代码生成上对抗 Rust?

...

取消回复欢迎 发表评论: