PostgreSQL 内置函数

PostgreSQL 提供了丰富的内置函数,用于执行各种操作,如数学计算、字符串处理、日期时间操作等。以下是一些常用的 PostgreSQL 内置函数及其说明:

1. 聚合函数

  • SUM(): 计算某列的总和。

    sql 复制代码
    SELECT SUM(column_name) FROM table_name;
  • AVG(): 计算某列的平均值。

    sql 复制代码
    SELECT AVG(column_name) FROM table_name;
  • COUNT(): 计算某列的行数。

    sql 复制代码
    SELECT COUNT(column_name) FROM table_name;
  • MIN(): 返回某列的最小值。

    sql 复制代码
    SELECT MIN(column_name) FROM table_name;
  • MAX(): 返回某列的最大值。

    sql 复制代码
    SELECT MAX(column_name) FROM table_name;

2. 字符串函数

  • LENGTH(): 返回字符串的长度。

    sql 复制代码
    SELECT LENGTH('Hello World');
  • SUBSTRING(): 提取字符串的子串。

    sql 复制代码
    SELECT SUBSTRING('Hello World' FROM 1 FOR 5);
  • CONCAT(): 连接两个或多个字符串。

    sql 复制代码
    SELECT CONCAT('Hello', ' ', 'World');
  • UPPER(): 将字符串转换为大写。

    sql 复制代码
    SELECT UPPER('hello');
  • LOWER(): 将字符串转换为小写。

    sql 复制代码
    SELECT LOWER('HELLO');

3. 数学函数

  • ABS(): 返回绝对值。

    sql 复制代码
    SELECT ABS(-10);
  • ROUND(): 四舍五入到指定的小数位数。

    sql 复制代码
    SELECT ROUND(123.4567, 2);
  • CEIL(): 返回大于或等于指定数的最小整数。

    sql 复制代码
    SELECT CEIL(123.456);
  • FLOOR(): 返回小于或等于指定数的最大整数。

    sql 复制代码
    SELECT FLOOR(123.456);
  • RANDOM(): 返回一个随机数。

    sql 复制代码
    SELECT RANDOM();

4. 日期和时间函数

  • NOW(): 返回当前日期和时间。

    sql 复制代码
    SELECT NOW();
  • CURRENT_DATE: 返回当前日期。

    sql 复制代码
    SELECT CURRENT_DATE;
  • CURRENT_TIME: 返回当前时间。

    sql 复制代码
    SELECT CURRENT_TIME;
  • AGE(): 计算两个日期之间的间隔。

    sql 复制代码
    SELECT AGE('2023-01-01', '2022-01-01');
  • EXTRACT(): 从日期或时间中提取部分(如年、月、日等)。

    sql 复制代码
    SELECT EXTRACT(YEAR FROM NOW());

5. 条件函数

  • COALESCE(): 返回参数列表中的第一个非空值。

    sql 复制代码
    SELECT COALESCE(NULL, 'default');
  • NULLIF(): 如果两个参数相等,则返回 NULL,否则返回第一个参数。

    sql 复制代码
    SELECT NULLIF(1, 1);
  • GREATEST(): 返回参数列表中的最大值。

    sql 复制代码
    SELECT GREATEST(1, 2, 3);
  • LEAST(): 返回参数列表中的最小值。

    sql 复制代码
    SELECT LEAST(1, 2, 3);

6. 类型转换函数

  • CAST(): 将一种数据类型转换为另一种。

    sql 复制代码
    SELECT CAST('123' AS INTEGER);
  • TO_CHAR(): 将日期/时间或数字转换为字符串。

    sql 复制代码
    SELECT TO_CHAR(NOW(), 'YYYY-MM-DD');
  • TO_DATE(): 将字符串转换为日期。

    sql 复制代码
    SELECT TO_DATE('2023-01-01', 'YYYY-MM-DD');

7. 数组函数

  • ARRAY_LENGTH(): 返回数组的长度。

    sql 复制代码
    SELECT ARRAY_LENGTH(ARRAY[1, 2, 3], 1);
  • ARRAY_AGG(): 将多行数据聚合为一个数组。

    sql 复制代码
    SELECT ARRAY_AGG(column_name) FROM table_name;

8. 窗口函数

  • ROW_NUMBER(): 为结果集中的每一行分配一个唯一的行号。

    sql 复制代码
    SELECT ROW_NUMBER() OVER (ORDER BY column_name) FROM table_name;
  • RANK(): 为结果集中的每一行分配一个排名,相同的值会有相同的排名。

    sql 复制代码
    SELECT RANK() OVER (ORDER BY column_name) FROM table_name;
  • DENSE_RANK() : 类似于 RANK(),但排名不会跳过重复的值。

    sql 复制代码
    SELECT DENSE_RANK() OVER (ORDER BY column_name) FROM table_name;

这些函数只是 PostgreSQL 提供的众多内置函数中的一部分。根据具体需求,你可以查阅 PostgreSQL 官方文档以获取更详细的函数列表和使用说明。

相关推荐
sun0077001 小时前
mysql索引底层原理
数据库·mysql
workflower4 小时前
MDSE和敏捷开发相互矛盾之处:方法论本质的冲突
数据库·软件工程·敏捷流程·极限编程
Tony小周4 小时前
实现一个点击输入框可以弹出的数字软键盘控件 qt 5.12
开发语言·数据库·qt
lifallen4 小时前
Paimon 原子提交实现
java·大数据·数据结构·数据库·后端·算法
TDengine (老段)5 小时前
TDengine 数据库建模最佳实践
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
Elastic 中国社区官方博客5 小时前
Elasticsearch 字符串包含子字符串:高级查询技巧
大数据·数据库·elasticsearch·搜索引擎·全文检索·lucene
Gauss松鼠会6 小时前
GaussDB应用场景全景解析:从金融核心到物联网的分布式数据库实践
数据库·分布式·物联网·金融·database·gaussdb
守城小轩6 小时前
Chromium 136 编译指南 - Android 篇:开发工具安装(三)
android·数据库·redis
尽兴-6 小时前
如何将多个.sql文件合并成一个:Windows和Linux/Mac详细指南
linux·数据库·windows·sql·macos
小小不董6 小时前
深入理解oracle ADG和RAC
linux·服务器·数据库·oracle·dba