sql – 在Oracle中使用IF ELSE
发布时间:2021-03-06 10:12:15 所属栏目:编程 来源:网络整理
导读:作为一名Web开发人员,我知道如何在多种语言中使用IF ELSE.但是,我正在学习如何使用TOAD for Oracle编写报告. 我的问题是,如何正确添加IF ELSE语句? 这就是我想要做的. 错误是:命令未正确结束. (VIKKIE和ICKY一直由我的主管负责帮助我学习) SELECT DISTINCT
|
作为一名Web开发人员,我知道如何在多种语言中使用IF ELSE.但是,我正在学习如何使用TOAD for Oracle编写报告. 我的问题是,如何正确添加IF ELSE语句? 这就是我想要做的. (VIKKIE和ICKY一直由我的主管负责帮助我学习) SELECT DISTINCT a.item,b.salesman,NVL(a.manufacturer,'Not Set')Manufacturer
FROM inv_items a,arv_sales b
WHERE a.co = '100'
AND a.co = b.co
AND A.ITEM_KEY = b.item_key
--AND item IN ('BX4C','BX8C','BX866') --AND salesman ='15'
AND a.item LIKE 'BX%'
AND b.salesman in ('01','15')
AND trans_date BETWEEN to_date('010113','mmddrr')
and to_date('011713','mmddrr')
GROUP BY a.item,a.manufacturer
ORDER BY a.item
IF b.salesman = 'VIKKIE' THEN
a.salesman := 'ICKY';
END IF;
解决方法IF是PL / SQL构造.如果您正在执行查询,则使用的是SQL而不是PL / SQL.在SQL中,您可以在查询本身中使用CASE语句 SELECT DISTINCT a.item,(CASE WHEN b.salesman = 'VIKKIE'
THEN 'ICKY'
ELSE b.salesman
END),'Not Set') Manufacturer
FROM inv_items a,arv_sales b
WHERE a.co = '100'
AND a.co = b.co
AND A.ITEM_KEY = b.item_key
AND a.item LIKE 'BX%'
AND b.salesman in ('01','15')
AND trans_date BETWEEN to_date('010113','mmddrr')
and to_date('011713','mmddrr')
ORDER BY a.item
由于您没有进行任何聚合,因此您不希望在查询中使用GROUP BY.你真的确定你需要DISTINCT吗?人们经常随意抛出它,或者在缺少连接条件时添加它,而不是考虑是否确实需要做额外的工作来识别和删除重复项. (编辑:广西网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐

