检查记录是否在Oracle中最有效的方法是什么? [英] What's the most efficient way to check if a record exists in Oracle?
本文介绍了检查记录是否在Oracle中最有效的方法是什么?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
A)
select decode(count(*), 0, 'N', 'Y') rec_exists
from (select 'X'
from dual
where exists (select 'X'
from sales
where sales_type = 'Accessories'));
B)
select decode(count(*), 0, 'N', 'Y') rec_exists
from (select 'X'
from sales
where sales_type = 'Accessories');
C)其他(指定)
很难选择正确的"答案,因为最佳方法取决于检查值是否存在之后要执行的操作,如APC所指出的那样.我最终选择了RedFilter作为答案,因为我最初将此项检查本身设想为一个功能.
It was hard to pick the "correct" answer, as the best approach depends on what you want to do after checking if the value exists, as pointed out by APC. I ended up picking the answer by RedFilter, since I had originally envisioned this check as a function by itself.
推荐答案
select case
when exists (select 1
from sales
where sales_type = 'Accessories')
then 'Y'
else 'N'
end as rec_exists
from dual;
这篇关于检查记录是否在Oracle中最有效的方法是什么?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文