PostgreSQL运算符

运算符

算数运算符

运算符 描述 示例
+ 加法 SELECT 2 + 3; 结果为 5
- 减法 SELECT 5 - 2; 结果为 3
* 乘法 SELECT 2 * 3; 结果为 6
/ 除法(对于整数相除,会截断小数部分) SELECT 5 / 2; 结果为 2 ,若要得到精确结果,可使用浮点数 SELECT 5.0 / 2; 结果为 2.5
% 取模(求余数) SELECT 5 % 2; 结果为 1
^ 幂运算 SELECT 2 ^ 3; 结果为 8

比较运算符

运算符 描述 示例
= 等于 SELECT 2 = 2; 结果为 TRUE
<> 或 != 不等于 SELECT 2 <> 3; 结果为 TRUE
< 小于 SELECT 2 < 3; 结果为 TRUE
> 大于 SELECT 3 > 2; 结果为 TRUE
<= 小于等于 SELECT 2 <= 2; 结果为 TRUE
>= 大于等于 SELECT 3 >= 2; 结果为 TRUE

逻辑运算符

运算符 描述 示例
AND 逻辑与,所有条件都为 TRUE 时结果才为 TRUE SELECT * FROM employees WHERE salary > 5000 AND department_id = 1;
OR 逻辑或,只要有一个条件为 TRUE 结果就为 TRUE SELECT * FROM employees WHERE salary > 5000 OR department_id = 1;
NOT 逻辑非,对条件结果取反 SELECT * FROM employees WHERE NOT salary > 5000;

字符串运算符

  • 连接运算符 ||

用于连接两个或多个字符串:

Bash 复制代码
	SELECT 'Hello' || ' ' || 'World';
	结果为 Hello World。
  • 模式匹配运算符

    • LIKE

    用于模糊匹配字符串,支持 %(匹配任意数量的任意字符)和 _(匹配单个任意字符)。

    Bash 复制代码
    -- 查找以 'J' 开头的客户姓名
    SELECT * FROM customers WHERE name LIKE 'J%'; 
    • ILIKE:与 LIKE 类似,但不区分大小写。
    Bash 复制代码
    -- 不区分大小写查找以 'J' 开头的客户姓名
    SELECT * FROM customers WHERE name ILIKE 'j%'; 
    • ~ 和 ~*:正则表达式匹配,~ 区分大小写,~* 不区分大小写。
    Bash 复制代码
    -- 使用正则表达式查找以 'J' 开头的客户姓名
    SELECT * FROM customers WHERE name ~ '^J.*'; 

位运算

运算符 描述 示例
& 按位与 SELECT 5 & 3; (二进制 101 & 011)结果为 1
| 按位或 SELECT 5 | 3;(二进制101|011)结果为 7
# 按位异或 SELECT 5 # 3; (二进制 101 # 011)结果为 6
~ 按位取反 SELECT ~5; 结果为 -6 (二进制补码表示)
<< 左移 SELECT 5 << 1; (二进制 101 左移一位)结果为 10
>> 右移 SELECT 5 >> 1; (二进制 101 右移一位)结果为 2

成员运算符

  • IN:用于判断一个值是否在指定的列表中。
Bash 复制代码
	SELECT * FROM employees WHERE department_id IN (1, 2, 3);
  • NOT IN:用于判断一个值是否不在指定的列表中。
Bash 复制代码
	SELECT * FROM employees WHERE department_id NOT IN (1, 2, 3);

空值比较运算符

  • IS NULL:用于判断一个值是否为 NULL。
Bash 复制代码
	SELECT * FROM employees WHERE manager_id IS NULL;
  • IS NOT NULL:用于判断一个值是否不为 NULL。
Bash 复制代码
	SELECT * FROM employees WHERE manager_id IS NOT NULL;
相关推荐
oMcLin17 分钟前
如何在 CentOS Stream 9 上配置并优化 PostgreSQL 15,支持高并发的数据插入与快速查询?
linux·postgresql·centos
Lupino35 分钟前
构建现代化的 Python PostgreSQL 工具库:psql_utils 的重构与优化之旅
python·postgresql
Chef_Chen1 小时前
数据科学每日总结--Day41--ubuntu安装tailscale
数据库·ubuntu·postgresql
柠檬叶子C13 小时前
PostgreSQL 忘记 postgres 密码怎么办?(已解决)
数据库·postgresql
光蛋15 小时前
PostgreSQL 显式锁定:从原理到实践(趣味版)
postgresql
2301_8002561116 小时前
数据库设计中的 “数据依赖→设计异常→关系分解(范式)” 核心逻辑
数据库·postgresql
码间拾光・菲林斯17 小时前
PostgreSQL 微服务架构开发实战:数据一致性、多租户设计与框架集成
微服务·postgresql·架构
IvorySQL17 小时前
PostgreSQL 的 SQL 查询之旅
数据库·人工智能·postgresql·开源
TimerShaft1 天前
CentOS7安装PostgresSQL和PGVector
postgresql·centos·pgvector
2301_800256111 天前
R-Tree创建与遍历,R-Tree在4类空间查询中的应用,实现4类空间查询的各类算法[第8章]
数据库·算法·机器学习·postgresql·r-tree