当前位置: 首页 > news >正文

[Oracle] DECODE()函数

DECODE() 是 Oracle 的一个非常强大且常用的条件表达式函数,它实现了类似于 if-then-else 或 case-when 的逻辑,但语法更为简洁

语法格式

DECODE(expression, search1, result1, [search2, result2, ...], [default])

参数说明
expression:要比较的值或表达式
search1, search2,...:要与 expression 比较的值
result1, result2,...:当 expression 与对应的 search 值匹配时返回的结果
default:可选参数,当没有匹配项时返回的默认值,如果省略且没有匹配项,则返回 NULL

DECODE()函数将 expression 依次与每个 search 值进行比较:
① 如果 expression 等于 search1,则返回 result1
② 如果不等于,则继续比较 search2,如果匹配则返回 result2
③ 依此类推,直到找到匹配项
④ 如果没有匹配项且提供了 default 参数,则返回 default 值
⑤ 如果没有匹配项且未提供 default 参数,则返回 NULL

示例

-- 简单的值比较
SELECT DECODE(1, 1, 'One', 2, 'Two', 'Other') FROM dual;  -- 'One'
SELECT DECODE(3, 1, 'One', 2, 'Two', 'Other') FROM dual;  -- 'Other'SELECT DECODE(1+2, 3, 'A', 'B') from dual;  -- 'A'
SELECT DECODE(1+2, 4, 'A', 'B') from dual;  -- 'B'-- 转换描述
SELECT order_id,DECODE(status, 'P', 'Pending','S', 'Shipped','D', 'Delivered','Unknown Status') AS status_desc
FROM orders;-- 数值范围判断
SELECT employee_name,salary,DECODE(SIGN(salary - 5000),-1, 'Low',0, 'Medium',1, 'High') AS salary_level
FROM employees;-- 多条件组合
SELECT product_id,DECODE(category, 'A', price*0.9,'B', price*0.8,'C', price*0.7,price) AS discounted_price
FROM products;-- 与聚合函数结合使用
SELECT department_id,COUNT(*) AS total,COUNT(DECODE(gender, 'M', 1, NULL)) AS male_count,COUNT(DECODE(gender, 'F', 1, NULL)) AS female_count
FROM employees
GROUP BY department_id;-- 嵌套DECODE()函数
SELECT employee_name,DECODE(DECODE(department, 'IT', 1, 'HR', 2, 0),1, 'Technical',2, 'Administrative','Other') AS employee_type
FROM employees;

提示Tips

① DECODE()函数对NULL值的处理:DECODE()认为 NULL 等于 NULL

SELECT DECODE(NULL, NULL, 'Equal', 'Not Equal') FROM dual;  -- 'Equal'

② 对于简单的条件判断,DECODE()通常比 CASE 表达式更高效,但对于复杂的多条件逻辑,CASE 表达式可能更清晰易读

③ DECODE()函数会尝试将所有参数转换为第一个 result 参数的数据类型

所有 result 值应最好保持相同或兼容的数据类型

http://www.dtcms.com/a/320089.html

相关文章:

  • [Oracle] GREATEST()函数
  • GCC与NLP实战:编译技术赋能自然语言处理
  • Kubernetes(k8s)之Service服务
  • 【C语言】深入理解编译与链接过程
  • Java中的反射机制
  • 【AxureMost落葵网】企业ERP项目原型-免费
  • 上位机知识篇篇---驱动
  • Xvfb虚拟屏幕(Linux)中文入门篇1:(wikipedia摘要,适当改写)
  • 函数、方法和计算属性
  • 计网学习笔记第3章 数据链路层(灰灰题库)
  • [激光原理与应用-169]:测量仪器 - 能量型 - 光功率计(功率稳定性监测)
  • 记录:rk3568适配开源GPU驱动(panfrost)
  • Linux中Docker Swarm实践
  • 12-netty基础-手写rpc-编解码-04
  • ubuntu 2024 安装拼音输入法
  • 【macOS操作系统部署开源DeepSeek大模型,搭建Agent平台,构建私有化RAG知识库完整流程】
  • Linux综合练习2
  • 电气设备与互感器全解析
  • 智能制造网络质量保障:德承 DX-1200多网口工控机在windows系统下的网络性能测试指南
  • 操作系统与并发底层原理多道技术
  • docker容器导出为镜像
  • 深度学习入门Day7:Transformer架构原理与实战全解析
  • 亚马逊广告运营:有什么好用的辅助工具
  • Redis配置、测试及分布式缓存实现
  • Android 之 Jetpack - Paging
  • 《C语言》函数练习题--2
  • ElasticSearch相关术语介绍
  • 使用 decimal 包解决 go float 浮点数运算失真
  • 小鸡模拟器安卓版:经典街机游戏的移动体验
  • 利用Axure与JavaScript打造动态图片上传原型:设计案例分享