PostgreSQL系列(一):数据类型和基本类型转换
liuian 2025-08-06 21:04 97 浏览
自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟技术相关的系列文章过过瘾,先从PG开始更新吧,后面再看写哪个方向的。
随着国内软件本土化的趋势,国产软件现在也慢慢发展起来了,通过查看招聘网站上的要求以及对国产数据库的一些了解,也发现不少产品底层都是基于PG做上去的,PG在流行程度上现在也开始逐渐超过MYSQL,这个产品还是值得研究一下的。
PG的安装和配置(远程连接配置、用户管理等)就不写了。今天主要记录一下PG的数据类型,通过与MySQL对比,先有一个整体的基本印象,接下来简单记录下类型转换的几种用法。
先说一下PG的几个技术文档网站地址:
官网:
https://www.postgresql.org/docs/,最新版本16.2,如果英文还不错,建议通过该文档学习,权威性最高。当然不是说国内做得不好,全看个人喜好
中文网站:
http://postgres.cn/v2/document,这里的版本更新到12
数据类型
先放一张表,稍微翻译一下
数据类型 | 别名 | 说明 |
bigint | int8 | signed eight-byte integer 有符号8字节整数 |
bigserial | serial8 | autoincrementing eight-byte integer 自增的8字节整数,这个类似于MySQL的字段设置auto increment |
bit [ (n) ] | fixed-length bit string 指定长度的位数组,长度必须为n,不能多也不能少,不写默认长度为1 | |
bit varying [ (n) ] | varbit [ (n) ] | variable-length bit string 可变长度的位数组,最大存储n个位,不写默认不限制 |
boolean | bool | logical Boolean (true/false) 布尔类型 |
box | rectangular box on a plane 描述一个长方形,有3种写法: 用坐标来描述,分别是左上角和右下角的坐标,通常用于地理位置标记 | |
bytea | binary data (“byte array”) 大容量二进制数据类型,类似于MYSQL的blob | |
character [ (n) ] | char [ (n) ] | fixed-length character string 固定长度的字符串,长度不够空白填充,填充在后面,比如字段设置为char(5),输入一个值tt后,存储的值实际为ttxxx,x表示空格 |
character varying [ (n) ] | varchar [ (n) ] | variable-length character string 变长的字符串,与MYSQL中的varchar(n)类似,最多容纳n个字符,不写与text类型一样效果 |
cidr | IPv4 or IPv6 network address IPV4或者IPV6地址存储,MYSQL存储还需要开发人员考虑一下数据设计,这里直接提供了数据类型 | |
circle | circle on a plane 与box一样,这是存储一个描述圆的数据 | |
date | calendar date (year, month, day) 日期,只表示年月日 | |
double precision | float8 | double precision floating-point number (8 bytes) 双精度浮点数,8个字节大小 |
inet | IPv4 or IPv6 host address IPV4或者IPV6地址,可以带子网掩码,以IPV4地址示例: 192.168.1.1/24,前面表示IP地址,/后面表示子网掩码,24表示的子网掩码为从高位往低位开头连续为24个1,也就是: 11111111 11111111 11111111 00000000,转成十进制就是255.255.255.0,这个子网掩码熟悉吧,应该好理解 | |
integer | int, int4 | signed four-byte integer 4字节有符号整数 |
interval [ fields ] [ (p) ] | time span 时间差 | |
json | textual JSON data 现在Web API返回值常用的JSON文本格式 | |
jsonb | binary JSON data, decomposed 二进制的JSON串,MongoDB用的这种,性能要比json好 | |
line | infinite line on a plane 表示线条,用法忽略 | |
lseg | line segment on a plane 表示线段,表示方式与线类似,唯一区别是线段有端点,用法忽略 | |
macaddr | MAC (Media Access Control) address MAC地址 | |
macaddr8 | MAC (Media Access Control) address (EUI-64 format) EUI-64位格式的MAC地址 | |
money | currency amount 货币数据类型 | |
numeric [ (p, s) ] | decimal [ (p, s) ] | exact numeric of selectable precision 指定整数部分和小数部分的浮点数,可与money做等价转换,不丢精度 |
path | geometric path on a plane 一系列点的连线 | |
pg_lsn | PostgreSQL Log Sequence Number PG日志位置索引,64位整数,通过该值可去PG的日志文件中查找该字段指定位置的流内容 | |
pg_snapshot | user-level transaction ID snapshot 用户级别的事务ID快照 | |
point | geometric point on a plane 表示点,用法忽略 | |
polygon | closed geometric path on a plane 表示多边形,用法忽略 | |
real | float4 | single precision floating-point number (4 bytes) 单精度的浮点数,4字节表示 |
smallint | int2 | signed two-byte integer 有符号的2字节整数 |
smallserial | serial2 | autoincrementing two-byte integer 自增序列,大小为2字节 |
serial | serial4 | autoincrementing four-byte integer 自增序列,大小为4字节 |
text | variable-length character string 大文本对象 | |
time [ (p) ] [ without time zone ] | time of day (no time zone) 不带时区的日期部分内容 | |
time [ (p) ] with time zone | timetz | time of day, including time zone 带时区的日期部分内容 |
timestamp [ (p) ] [ without time zone ] | date and time (no time zone) 包含年月日时分秒的格式,不带时区 | |
timestamp [ (p) ] with time zone | timestamptz | date and time, including time zone 包含年月日时分秒的格式,带时区 |
tsquery | text search query 全文搜索,这个一般用专门的全文搜索数据库,比如ES,这里不再赘述 | |
tsvector | text search document 该字段存储的数据会被进行分词,这个一般用专门的全文搜索数据库,比如ES,这里不再赘述 | |
txid_snapshot | user-level transaction ID snapshot (deprecated; see pg_snapshot) 已过时,由pg_snapshot替代 | |
uuid | universally unique identifier UUID,再熟悉不过啦 | |
xml | XML data XML文本数据 |
说明:
- pg中char、varchar、text3个类型性能没区别
- 类似box、circle等表示形状的数据类型一般用不到,都直接用类似于ES这种专门的NoSQL来处理,只做了解,不深入研究了
- 每个数据类型后面要单独进行分析,有的字段还挺复杂,原理也得看一看,方便理解
基本类型转换
- 单引号与双引号
- 单引号用于表示字符串,比如插入一个文本test,写值的时候就要写成'test'
- 双引号里面引用的必须是关键字,避免与PG的关键字冲突,其用法与MYSQL的''类似。举例:某表的字段名叫select,此时查询该字段时必须写成select "select" from XXX。通常要避免出现这种情况,这并不是一个好的工程实践。
- 类型转换
类型转换有3种写法:
第一种:类 型值
select int '123'
第二种:值::类型
select '123'::int
第三种:cast(类型 值 as 转换后的类型)
select cast(varchar '123' as int)
前2种写法本质上来说,最终都是调用了第3种方法的实现。
好,今天先写到这,明天继续更新。最近打算做个技术人的人生经历,问下老K看看能不能提供点素材,那么多年的交情,老麻雀应该不会不答应
- 上一篇:基于MCP实现text2sql
- 下一篇:解决JPA在多线程中事务无法生效的问题
相关推荐
- 系统门窗一线品牌有哪些(中国系统门窗一线品牌有哪些)
-
轩尼斯门窗轩尼斯门窗创立于2004年,总部植根于佛山,生产基地在广东江苏共有4个,分别在凤岗厂区、盐城厂区、官窑厂区和范湖厂区;轩尼斯门窗在创建伊始就自主研发出了首款断桥铝门窗,产品技术专利超100项...
- 笔记本显卡天梯图排行榜(笔记本显卡天梯图最新版)
-
1、华硕ASUSROG-STRIX-RTX3080-O10G-GAMING1440-1935MHz华硕RTX3080被称为猛禽显卡,它将ROGSTRIX的轴流风扇进一步升级,扇叶数量也进行了...
- 惠普打印机售后维修官网(惠普打印机官方维修点查询)
-
是位于唐河县城区的惠普授权服务中心。这家维修点提供惠普打印机的售后服务和维修,包括故障排查、维修、更换零部件等。他们的技术人员都经过惠普的专业培训,能够提供高质量的服务。如果您的惠普打印机出现了问题,...
- 万能网卡驱动下载win11(万能网卡驱动windows7版2018最新版)
-
在windows11系统中点击桌面下方的开始图标,打开设置页面鼠标点击选择设备管理器选项。找到其中的网络适配器功能。右键选择显卡,点击卸载设备按钮等待卸载完成后重新安装驱动并重启计算机设备即可。想要修...
- cpu总是100使用率怎么回事呢
-
CPU占用率100%可能有多种原因。以下是一些可能的原因:驱动没有经过认证,这可能导致CPU资源占用100%。杀毒软件可能会占用大量的CPU资源,因为它们需要实时监控网页、邮件、个人隐私等功能。病毒或...
- 苹果6怎么升级系统版本(苹果6怎么升级系统版本最高能到多少)
-
要是喜欢自己动手可以自己去官网上下载,新系统在更新,他只是不支持自动更新的。如果不想自己动手,可以去拼多多或者是淘宝里面找一找,多的是那种帮你刷新系统的。也就是一点点钱的事情。现在选择很多活人不会被尿...
- windows2003镜像32位下载(win2003系统镜像)
-
虚拟光驱装系统,(win7,xp通用)具体步骤一、将从网上下载的win7旗舰版ISO系统文件存放到D盘。二、从网上下载虚拟光驱,打开安装后在任务栏右通知区显示“虚拟DAEMON管理器”图标,在我的电脑...
- win10电脑自动更新怎么关闭(win10电脑怎么关闭自动更新系统)
-
win10老推送win11打开的方法步骤如下,1,首先,打开设置,点击更新和安全2,打开后,点击windows预览体验计划3,打开后,点击开始4,然后按流程进行注册5,注册完成后,点击选择帐户6,然后...
- window7下载steam(window7下载一键重装如何恢复网络)
-
回答如下:要在Windows7上下载Steam,您可以按照以下步骤操作:1.打开您的浏览器,访问Steam官网(https://store.steampowered.com)。2.点击页面右上角...
- 系统还原没有还原点怎么办(系统还原点不动怎么办)
-
如果电脑没有创建还原点,就不能使用系统还原来回到之前的状态。但是,可以尝试使用其他备份工具或软件来恢复数据或重建系统。比如,可以使用第三方备份软件来备份重要文件和数据。如果是系统出现问题,可以尝试重新...
- 正在准备windows(正在准备windows请勿关机怎么办)
-
这个情况在使用华为电脑时可能会遇到。一般来说,这是因为电脑正在进行系统更新或者安装软件程序等操作,导致启动时间较长。如果电脑显示“正在准备Windows,请勿关闭电源”,则说明电脑正在进行系统更新。...
-
- 有win10安装包怎么装系统(win10安装包安装教程)
-
如果是原版ISO镜像,可以加载到虚拟光驱直接安装。如果是第三方更改的就需要启动盘。个人建议用U盘启动盘来安装。下载一个u盘启动盘程序(优启通、大白菜……),按照提示把它安装到U盘。启动盘制作完毕以后,启动电脑安快捷键选择U盘启动。进入pe后...
-
2026-01-14 16:37 liuian
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
