OCP 1Z0 051 V9 02 100题

本文深入探讨了SQL中的DECODE函数用法,通过具体示例展示了如何使用DECODE进行条件判断和结果返回,适用于Oracle数据库环境。文章还解析了常见错误及语法误区。

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.youkuaiyun.com/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

               

100. View the Exhibit and examine the structure of the PROMOTIONS table.

Which SQL statements are valid?  (Choose all that apply.) 

A. SELECT promo_id, DECODE(NVL(promo_cost,0), promo_cost,                        

promo_cost * 0.25, 100) "Discount"

FROM promotions;

B. SELECT promo_id, DECODE(promo_cost, 10000,       

DECODE(promo_category, 'G1', promo_cost *.25, NULL),       

NULL) "Catcost"

FROM promotions;

C. SELECT promo_id, DECODE(NULLIF(promo_cost, 10000),                        

NULL, promo_cost*.25, 'N/A') "Catcost"

FROM promotions;

D. SELECT promo_id, DECODE(promo_cost, >10000, 'High',                                  

<10000, 'Low') "Range"

FROM promotions;

Answer: AB
答案解析:

C不正确,因为把’N/A’隐式转换成数值时不成功。D语法不正确。

DECODE(expr,search1,result1[,search2,result2……,default]):比较expr与search,如果等于search1则返回result1,如果等于search2则返回result2,依次类推,如果都不等于,如果有default则返回default,否则返回NULL.

ORACLE在比较之前,会自动把expr和每一个search隐式转换成第一个search(search1)的数据类型。自动把返回值转换成第一个result(result1)的数据类型。如果第一个result的数据类型为CHAR或者值是null,则Oracle转换返回值为VARCHAR2.

在DECODE函数中,NULL是相等的,如果expr为空,则Oracle将会返回第一个为NULL的search所对应的result。DECODE列表中的最大表达式个数为255个。

           

给我老师的人工智能教程打call!http://blog.youkuaiyun.com/jiangjunshow
这里写图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值