pgsql常用函数

字符处理类

COALESCE(column_name, 指定值)

将空值(NULL)转为指定值,column_name为字段名,逗号后可以指定值。如COALESCE(id, 0)

SPLIT_PART(字符串, 分隔符, 位置索引)

返回字符串中按分隔符分隔的指定序号字符

如:SELECT split_part('12-13-14', '-', 2) 返回13

SELECT split_part('12-13-14', '-', 3) 返回14

CONCAT(字符串,字符串)

将多个字符串拼接到一起

TRIM()

去除字符串两端的空格,如SELECT trim(' hello ! ') 输出'hello !'

时间处理

TO_TIMESTAMP()

时间戳转日期时间,毫秒级的时间戳需要先÷1000

SELECT TO_TIMESTAMP(1635388200) 输出2021-10-28 10:30:00+08

SELECT TO_TIMESTAMP(1635388200000/1000) 输出2021-10-28 10:30:00+08

TO_CHAR()

格式化日期时间为指定字符串

SELECT TO_CHAR(NOW(), 'YYYY-MM-DD HH24:MI:SS');

-- 输出:2025-10-28 14:42:34

EXTRACT()

提取日期时间的组成部分

SELECT EXTRACT(YEAR FROM NOW()) AS year,

EXTRACT(MONTH FROM NOW()) AS month,

EXTRACT(DAY FROM NOW()) AS day;

使用+/-进行日期加减

INTERVAL后可以加minutes,SECOND,也可以进行组合,如INTERVAL '1 year 2 months 3 days'

Json数据处理

jsonb_array_elements

展开JSON数组为多行

jsonb_set(target jsonb, path text[], new_value jsonb, [create_missing boolean])

更新现有键的值:通过指定路径,替换对应位置的值。

添加新键:如果路径不存在且create_missing为true,则创建新键。

如:UPDATE mo_trail_order_detail SET attr_value = jsonb_set ( attr_value, '{order_no}', case when attr_value ->> 'order_no' is not null then to_jsonb(attr_value ->> 'order_no' || ',A001' ) ELSE '"A001"' END, TRUE ) WHERE ID = 1221

jsonb_build_array(any)

构造列表对象

jsonb_build_object(any)

构造object对象

如:jsonb_build_object('customer_code',customer_code)

相关推荐
m0_6138562932 分钟前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
Adios79442 分钟前
VPR:Pitts50K和Norland数据集下载
数据库
东风破1371 小时前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
abcnull1 小时前
用javaparser做精准测试
java·ast·静态代码分析·精准测试·javaparser
叶小鸡1 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
收获不止数据库1 小时前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
小宇的天下1 小时前
Virtuoso GUI 界面中的关键模块定义
数据库
bqq198610261 小时前
MySQL 5.7 与 MySQL 8.0 的主要区别
数据库·mysql
juniperhan1 小时前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink