Oracle OCP认证考试题目详解082系列第49题

一、考察的知识点摘要

本题主要考察对Oracle数据库中 NULLIFCOALESCE 这两个函数的语法规则返回值逻辑的理解。核心知识点包括:

  1. NULLIF(expr1, expr2) 函数 :比较两个表达式。如果二者相等,返回NULL;如果不相等,返回第一个表达式 expr1 的值。特别注意 :第一个参数 expr1 不能直接为字面量 NULL
  2. COALESCE(expr1, expr2, ..., expr_n) 函数 :返回参数列表中第一个非空(NOT NULL)表达式 的值。如果所有参数均为NULL,则返回NULL。该函数需要至少两个参数。
  3. 数据类型一致性:在调用这些函数时,提供的参数应在数据类型上是兼容或可隐式转换的,否则可能导致错误。

二、英文题目与答案

题目 :Which two queries execute successfully?

A. SELECT NULLIF(100, 100) FROM DUAL;

B. SELECT NULLIF(100, 'A') FROM DUAL;

C. SELECT COALESCE(100, 'A') FROM DUAL;

D. SELECT COALESCE(100, NULL, 200) FROM DUAL;

E. SELECT NULLIF(NULL, 100) FROM DUAL;

正确答案AD

三、题目翻译

哪两个查询可以成功执行?

A. SELECT NULLIF(100, 100) FROM DUAL;

B. SELECT NULLIF(100, 'A') FROM DUAL;

C. SELECT COALESCE(100, 'A') FROM DUAL;

D. SELECT COALESCE(100, NULL, 200) FROM DUAL;

E. SELECT NULLIF(NULL, 100) FROM DUAL;

四、题目解析

  1. 选项A解析:正确执行NULLIF(100, 100) 比较两个数值100。由于它们相等,根据函数定义,返回 NULL。这是一个有效的函数调用,查询语法正确。
  2. 选项B解析:执行错误NULLIF(100, 'A') 试图比较一个数字(100)和一个字符串('A')。在Oracle数据库中,数字和字符串属于不同的数据类型。虽然数据库可能尝试隐式转换,但在严格的类型检查或无法进行合理转换的场景下,这种类型不匹配可能导致错误。
  3. 选项C解析:执行错误COALESCE(100, 'A') 试图返回第一个非NULL值。这里100是数字,'A'是字符串。COALESCE 函数要求所有参数的数据类型一致或可隐式转换为同一类型。数字和字符串的混合类型通常会导致错误。
  4. 选项D解析:正确执行COALESCE(100, NULL, 200) 从参数列表中寻找第一个非NULL值。第一个参数100就是非NULL的,因此函数返回100。这是一个语法和逻辑都正确的COALESCE函数调用,符合其需要至少两个参数的要求。
  5. 选项E解析:执行错误NULLIF(NULL, 100) 的第一个参数直接是字面量 NULL。根据 NULLIF 函数的定义,第一个参数不允许为字面量 NULL 。虽然逻辑上比较NULL和100不相等应返回第一个参数NULL,但Oracle语法规则明确禁止这种写法,会导致错误。

五、考察的知识点详情

  1. NULLIF 函数深度解析

    • 逻辑等价NULLIF(expr1, expr2) 在逻辑上完全等价于以下的 CASE 表达式:

      sql 复制代码
      CASE WHEN expr1 = expr2 THEN NULL ELSE expr1 END
    • 返回值类型NULLIF 函数的返回值数据类型与第一个参数 expr1 的数据类型相同。

    • 常见应用场景

      • 防止除零错误 :在除法运算中,使用 NULLIF 将分母为零的情况转换为 NULL,从而避免运行时错误。例如:SELECT 100 / NULLIF(0, 0) FROM DUAL; 结果是 NULL 而非错误。
      • 数据清洗 :将数据中特定的占位符(如表示无效值的999)转换为 NULL。例如:SELECT NULLIF(salary, 999) FROM employees;
  2. COALESCE 函数深度解析

    • 逻辑等价COALESCE(expr1, expr2, ..., expr_n) 可以用 CASE 表达式实现:

      sql 复制代码
      CASE WHEN expr1 IS NOT NULL THEN expr1 ELSE COALESCE(expr2, ..., expr_n) END

      最简单的形式 COALESCE(expr1, expr2) 等价于:

      sql 复制代码
      CASE WHEN expr1 IS NOT NULL THEN expr1 ELSE expr2 END
    • 短路评估(Short-circuit Evaluation) :Oracle数据库在计算 COALESCE 函数时采用短路评估。它会从左到右依次评估参数,一旦找到第一个非NULL值,就立即返回该值,并停止评估后续参数。这能提升性能。

    • NVL 函数的关系COALESCENVL 函数的泛化。NVL(expr1, expr2) 等价于 COALESCE(expr1, expr2),但 COALESCE 可以接受两个以上的参数,更为灵活。

  3. 关键区别与注意事项

    • 核心功能NULLIF 用于在特定条件(两值相等)下产生NULL ;而 COALESCE 用于从一系列值中寻找第一个非NULL
    • 参数限制NULLIF 必须且只能 接受两个参数。COALESCE 必须接受至少两个参数。
    • 数据类型一致性:两个函数都要求参数数据类型兼容。不兼容的数据类型(如选项B和C中的数字和字符串直接比较)是常见的错误来源。
    • NULL 字面量的使用 :特别注意 NULLIF 函数的第一个参数不能是字面量 NULL(如选项E),这是一个语法限制。

希望这份详细的解析能帮助你彻底理解 NULLIFCOALESCE 函数的相关知识。如果对SQL中的其他函数或概念还有疑问,我们可以继续探讨。

相关推荐
爱可生开源社区1 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
蝎子莱莱爱打怪1 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes
随逸1771 天前
《从零搭建NestJS项目》
数据库·typescript
DianSan_ERP2 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
加号32 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏2 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐2 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
呉師傅2 天前
火狐浏览器报错配置文件缺失如何解决#操作技巧#
运维·网络·windows·电脑
不是二师兄的八戒2 天前
Linux服务器挂载OSS存储的完整实践指南
linux·运维·服务器
百锦再2 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip