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中的其他函数或概念还有疑问,我们可以继续探讨。

相关推荐
DBA小马哥6 小时前
Oracle迁移实战:如何轻松跨越异构数据库的学习与技术壁垒
数据库·学习·oracle·信创·国产化平替
哇哈哈&6 小时前
gcc9.2的离线安装,支持gcc++19及以上版本
linux·运维·服务器
暮乘白帝过重山6 小时前
ArkTS ForEach 参数解析:组件与键值生成器
开发语言·数据库
一条咸鱼¥¥¥6 小时前
【运维经验】使用QQ邮箱SMTP服务器设置ssms计划任务完成时邮件发送
运维·服务器·经验分享·sql·sqlserver
【上下求索】6 小时前
学习笔记095——Ubuntu 安装 lrzsz 服务?
运维·笔记·学习·ubuntu
菜鸟plus+6 小时前
N+1查询
java·服务器·数据库
子夜江寒7 小时前
MySQL 表创建与数据导入导出
数据库·mysql
菜鸟小九7 小时前
redis基础(安装配置redis)
数据库·redis·缓存
保定公民7 小时前
达梦数据库使用cp备份集恢复报错分析与解决
数据库
Caster_Z8 小时前
WinServer安装VM虚拟机运行Linux-(失败,云服务器不支持虚拟化)
linux·运维·服务器