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;
相关推荐
在未来等你1 天前
高级SQL技巧:PostgreSQL高级特性实战指南
sql·postgresql·性能优化·窗口函数·递归查询
Mr.朱鹏2 天前
SQL实战之索引失效案例详解
java·数据库·spring boot·sql·mysql·spring·postgresql
数巨小码人3 天前
PostgreSQL中的权限管理简介
数据库·postgresql
rosemary5123 天前
Ubuntu 20.04 postgresql
linux·ubuntu·postgresql
运维老曾3 天前
PostgreSQL 用户权限与安全管理
数据库·postgresql
伊织code3 天前
macOS 安装 PostgreSQL
数据库·macos·postgresql·gui·安装·客户端·psql
运维老曾4 天前
PostgreSQL 软件升级
数据库·postgresql
运维老曾4 天前
在ubuntu 24安装 postgresql 17 (源码安装)
linux·ubuntu·postgresql
king_harry5 天前
PostgreSQL14 +patroni+etcd+haproxy+keepalived 集群部署指南
postgresql·pg高可用
king_harry5 天前
postgresql-14 高可用(pgpool)部署
postgresql·pg高可用