百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

数据库大师成长日记:最全PostgreSQL数据类型整理,敬请收藏

toyiye 2024-06-22 20:29 12 浏览 0 评论

PostgreSQL被业界誉为“最先进的开源数据库”。其中很重要的一条,就是因为PostgreSQL在所有关系型数据库中支持的数据类型最广泛很多都是独有的,甚至有一些连高价的商用数据库都不支持

正是因为PostgreSQL支持的数据类型太广泛了,很多朋友觉得理解起来很费劲,我这里将其做一个整理,希望可以作为您参考的资料。

数值类型

数值类型支持的非常广泛,serial类型大部分数据库不多见或者使用了其它方式实现。

货币类型

货币类型很好的处理舍入误差,尽量不要使用其它的浮点数类型。类似于SQL Server中的money和smallmoney类型。

字符类型

字符类型主要存储字符串,类似于SQL Server中的char、varchar、text等。

二进制数据类型

bytea数据类型允许存储二进制格式数据,类似于SQL Server中的Blob类型。

日期时间类型

记录日期和时间,类似于SQL Server的datetime、smalldatetime等,当类型更丰富。

布尔类型

大部分数据库不支持布尔类型,SQL Server中有一种tinyint类型,但终归算是整数类型。

枚举类型

枚举数据类型,包括静态,有序设置的值。需要用CREATE TYPE创建,一旦产生,它们可以像任何其他类型。枚举类型的定义方式如下:

CREATE TYPE sex AS ENUM ('男', '女', '妖'); 

几何类型

几何类型描述二维空间对象。其它数据库基本没有这种类型。

网址类型(IP)

大部分数据库不支持该类型,该类型可存储IPv4,IPv6的地址和MAC地址。

位串类型

位串类型用于存储位掩码。他们要么是0或1。其它数据库一般没有该类型。有两种 SQL 位类型:bit(n) 和 bit varying(n) ,这里的 n 是一个正整数。

文本搜索类型

该类型支持全文检索,主要有两种类型。

UUID类型

这种标识符是一个128位的量,它由一个精心选择的算法产生,该算法能保证在已知空间中任何其他使用相同算法的人能够产生同一个标识符的可能性非常非常小。

十六进制数字序列,由连字号,特别是一组8位数字,然后由三组4位数字,然后由一组12位数字分开几组,总32位。例如:7F4FB1C4-7D02-4D4D-B032-570F143F8C48。这种类型大部分数据库是没有的。

XML类型

主要用来存储XML数据。

Json类型

主要用来存储Json数据,而且支持丰富的Json操作和查询。

阵列/数组类型

可将列定义为可变长度的多维数组,支持任何内置或用户定义的基本类型数组、枚举类型,或者创建的其它复合型。

在使用时,[]表示一维数组,[][]表示二维数组,依次类推。比如text[][]。

复合类型

复核类型类似于一张表结构,但又可以作为其它表字段的类型。复合类型需要使用CREATE TYPE创建,比如:

CREATE TYPE Computer AS(
 cpu: numeric,
 memory: integer,
 disk: integer
)
CREATE TABLE Network AS(
 Workstation: Computer,
 Server: Computer,
 Position: varchar(100)
)

范围类型

范围类型可以是离散的范围,比如所有1到10的整数值,也可以是连续范围,比如任何时间点上午10点到下午两点。

对象标识符类型

主要是用来描述主键的类型。

伪类型

伪类型不能作为表字段的类型,但可以作为函数中的参数、结果的类型。伪类型在一个函数不只是简单地接受并返回某种 SQL 数据类型的情况下很有用。

怎么样朋友?PostgreSQL支持的数据类型是否大大出乎您的预料?“最先进的开源数据库”这名头还真不是盖的!

相关推荐

Asterisk-ARI对通道中的DTMF事件处理

Asterisk通道中关于DTMF处理是一个非常重要的功能。通过DTMF可以实现很多的业务处理。现在我们介绍一下关于ARI对通道中的DTMF处理,我们通过自动话务员实例来说明Asterisk如何创建一...

PyQt5 初次使用(pyqt5下载官网)

本篇文章默认已安装Python3,本篇文章默认使用虚拟环境。安装pipinstallPyQt5PyQt一些图形界面开发工具QtDesigner、国际化翻译工具Liguist需要另外...

Qt开发,使用Qt for Python还是Qt C++ Qt开发,使用Qt for

Qt开发使用QtforPython还是QtC++?1.早些年写过一个PyQt5的项目,最近几年重构成QtC++了,其中有个人原因,如早期代码写得烂,...

最简单方法!!用python生成动态条形图

最近非常流行动态条形图,在B站等视频网站上,此类视频经常会有上百万的播放量,今天我们通过第三方库:bar_chart_race(0.2版本)来实现动态条形图的生成;生成的效果如图:问题:...

Asterisk通道和ARI接口的通信(aau通道数)

Asterisk通道和ARI详解什么是通道Asterisk中,通道是介于终端和Asterisk自己本身的一个通信媒介。它包含了所有相关信息传递到终端,或者从终端传递到Asterisk服务器端。这些信...

Python GUI-长链转短链(长链接转化成短链接java)

当我们要分享某一个链接给别人,或是要把某个链接放入帖子中时,如果链接太长,则会占用大量空间,而且很不美观。这时候,我们可以结束长链转短链工具进行转换。当然可以直接搜索在线的网站进行转换,但我们可以借此...

Python 的hash 函数(python的hash函数)

今天在看python的hash函数源码的时候,发现针对不同的数据类型python实现了不同的hash函数,今天简单介绍源码中提到的hash函数。(https://github.com/pyth...

8款Python GUI开源框架,谁才是你的菜?

作为Python开发者,你迟早都会用到图形用户界面来开发应用。本文千锋武汉Python培训小编将推荐一些PythonGUI框架,希望对你有所帮助。1、Python的UI开发工具包Kivy...

python适合开发桌面软件吗?(python可不可以开发桌面应用软件)

其实Python/Java/PHP都不适合用来做桌面开发,Java还是有几个比较成熟的产品的,比如大名鼎鼎的Java集成开发环境IntelliJIDEA、Eclipse就是用Java开发的,不过PH...

CryptoChat:一款功能强大的纯Python消息加密安全传输工具

关于CryptoChatCryptoChat是一款功能强大的纯Python消息加密安全传输工具,该工具专为安全研究专家、渗透测试人员和红蓝队专家设计,该工具可以完全保证数据传输中的隐私安全。该工具建立...

为什么都说Python简单,但我觉得难?

Python普遍被大家认为是编程语言中比较简单的一种,但有一位电子信息的学生说自己已经学了C语言,但仍然觉得Python挺难的,感觉有很多疑问,像迭代器、装饰器什么的……所以他提出疑问:Python真...

蓝牙电话-关联FreeSwitch中继SIP账号通过Rest接口

蓝牙电话-关联FreeSwitch中继SIP账号通过Rest接口前言上一篇章《蓝牙电话-与FreeSwitch服务器和UA坐席的通话.docx》中,我们使用开源的B2B-UA当中经典的FreeSWIT...

技术分享|Sip与WebRTC互通-SRProxy开源库讲解

SRProxy介绍目前WebRTC协议跟SIP协议互通场景主要运用在企业呼叫中心、企业内部通信、电话会议(PSTN)、智能门禁等场景,要想让WebRTC与SIP互通,要解决两个层面的...

全网第N篇SIP协议之GB28181注册 JAVA版本

鉴于网上大部分关于SIP注册服务器编写都是C/C++/python,故开此贴,JAVA实现也贴出分享GB28181定义了了基于SIP架构的视频监控互联规范,而对于多数私有协议实现的监控系统...

「linux专栏」top命令用法详解,再也不怕看不懂top了

在linux系统中,我们经常使用到的一个命令就是top,它主要是用来显示系统运行中所有的进程和进程对应资源的使用等信息,所有的用户都可以使用top命令。top命令内容量丰富,可令使用者头疼的是无法全部...

取消回复欢迎 发表评论:

请填写验证码