[Oracle] GREATEST()函数

GREATEST()是 Oracle 的一个非常有用的比较函数,它可以从一组表达式中找出最大的值

GREATEST()函数在处理多值比较、数据筛选和条件逻辑时特别实用

语法格式

sql 复制代码
GREATEST(expr1, expr2 [, expr3, ...])

参数说明

expr1, expr2, ...:要比较的表达式(至少需要两个参数),可以是列名、常量、函数或计算表达式

GREATEST()函数可以比较数值、日期或字符类型的值,并且所有比较的参数类型需保持相同

示例

sql 复制代码
-- 比较两个数值
SELECT GREATEST(10, 20) FROM dual;  -- 20

-- 比较多个数值
SELECT GREATEST(5, 10, 8, 3, 15) FROM dual;  -- 15

-- 与列数据比较
SELECT product_id, 
       price, 
       discount_price,
       GREATEST(price, discount_price) AS effective_price
FROM products;

-- 确保值不低于最小值
UPDATE employees
SET salary = GREATEST(salary, 5000)
WHERE department_id = 10;

-- 计算最高得分
SELECT player_name,
       GREATEST(score1, score2, score3) AS best_score
FROM game_results;

-- 与CASE表达式结合
SELECT product_id,
       CASE 
         WHEN GREATEST(price1, price2, price3) > 100 THEN '高价'
         ELSE '普通'
       END AS price_level
FROM products;

-- 生成销售报表,显示最高销售额
SELECT region,
       GREATEST(Q1_sales, Q2_sales, Q3_sales, Q4_sales) AS peak_sales
FROM regional_sales;

-- 比较日期
-- 结果: 2025-08-15
SELECT GREATEST(TO_DATE('2025-01-01', 'YYYY-MM-DD'),
                TO_DATE('2025-08-15', 'YYYY-MM-DD'),
                TO_DATE('2025-03-12', 'YYYY-MM-DD'))
FROM dual;

-- 比较字符串(按字母顺序)
SELECT GREATEST('Apple', 'Banana', 'Cherry') FROM dual;  -- 'Cherry'

-- 比较混合数据类型
-- Oracle会尝试隐式转换
SELECT GREATEST(100, '200') FROM dual;  -- 200(字符串'200'被转换为数字)
sql 复制代码
SELECT GREATEST(10, NULL) FROM dual;  -- NULL

SELECT GREATEST(NULL, NULL, NULL) FROM dual;  -- NULL

SELECT GREATEST(10, NULL, 20) FROM dual;  -- NULL

SELECT GREATEST(10, NULL, 20, NULL) FROM dual;  -- NULL

提示Tips

① GREATEST()函数的输入值为NULL,其输出值也为NULL

② 尽量比较相同数据类型的值,保持数据类型一致性,隐式转换可能导致意外结果或错误

③ 在WHERE子句中使用GREATEST()通常会使索引失效

sql 复制代码
-- 不推荐(索引可能无法使用)
SELECT * FROM table WHERE GREATEST(col1, col2) > 100;

-- 推荐写法
SELECT * FROM table WHERE col1 > 100 OR col2 > 100;
相关推荐
这个DBA有点耶4 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶6 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技7 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend8 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence11 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql