我试图从all_tab_columns中获取传入IN子句的特定列的列计数,例如:
select count(COLUMN_NAME) 
  from ALL_TAB_COLUMNS 
 WHERE owner='SA' and COLUMN_NAME IN ('CASE_REPORTER2SITE', 'PRIMARY2BUS_ORG') 
 GROUP BY COLUMN_NAME 
HAVING COLUMN_NAME IN ('CASE_REPORTER2SITE', 'PRIMARY2BUS_ORG')
 ORDER BY DECODE (COLUMN_NAME, 'CASE_REPORTER2SITE', 1 'PRIMARY2BUS_ORG', 2)在这里,当两个列都存在于数据库中时,它给出了两列在2行中的计数。
结果:
COUNT(COLUMN_NAME)
------------------
2
4但是,当我传递一个现有列和一个不存在列时,如下所示:
select count(COLUMN_NAME) 
  from ALL_TAB_COLUMNS 
 WHERE owner='SA' and COLUMN_NAME IN ('CASE_XYZ', 'PRIMARY2BUS_ORG') 
 GROUP BY COLUMN_NAME 
HAVING COLUMN_NAME IN ('CASE_XYZ', 'PRIMARY2BUS_ORG')
 ORDER BY DECODE (COLUMN_NAME, 'CASE_XYZ', 1 'PRIMARY2BUS_ORG', 2)(假设CASE_XYZ不存在)。它给了我一排的计数结果。
结果:
COUNT(COLUMN_NAME)
------------------
4预期结果:
COUNT(COLUMN_NAME)
------------------
0
4如果特定列不存在,如何将其计数为0?
发布于 2016-01-19 13:56:49
您可以使用left join解决这个问题。使用智能子查询,这也消除了in和order by中的decode()。
我想把这个问题说成:
with cols as (
      select 'CASE_REPORTER2SITE' as col, 1 as ordering from dual union all
      select 'PRIMARY2BUS_ORG', 2 as ordering from dual
     )
select cols.col, count(atc.col_name)
from cols left join
     all_tab_columns atc
     on cols.col = atc.col_name and atc.owner = 'SA'
group by cols.col
order by max(cols.ordering);注意:我还在输出中包含了列名,因为我认为这是一个很好的实践。
发布于 2016-01-19 13:46:51
Mmmm,我能想到的唯一方法是使用从双、左外部联接创建的self来连接all_Tab_columns表,以保留空值,并在空时放置0,如下所示:
select t.column_name,case when count is null then 0 else count end from (
SELECT 'CASE_XYZ' as colname from dual
union
SELECT 'PRIMARY2BUS_ORG' from dual) t
left outer join (
select column_name, count(COLUMN_NAME) as count from ALL_TAB_COLUMNS
WHERE owner='SA' and COLUMN_NAME IN ('CASE_XYZ', 'PRIMARY2BUS_ORG')
GROUP  BY COLUMN_NAME HAVING COLUMN_NAME IN ('CASE_XYZ', 'PRIMARY2BUS_ORG')
ORDER BY DECODE (COLUMN_NAME, 'CASE_XYZ', 1 'PRIMARY2BUS_ORG', 2)) s
on t.colname = s.column_namehttps://stackoverflow.com/questions/34878136
复制相似问题