sql – Oracle – 将多个计数作为一个查询返回

我有几个问题,详情如下.我希望能够运行一个返回两个计数的SQL查询,这可能吗?

1.

select nvl(count(rowid),0) from tablename where OPP = 'FOO' and date = 'BAZ';

2.

select nvl(count(rowid),0) from tablename where OPP = 'BAR' and date = 'BAZ';

到目前为止,我只在搜索中找到了MSsql特定的解决方案.

解决方法

如果您需要它们在一行中:
SELECT
    COUNT(CASE OPP WHEN 'FOO' THEN 1 END),COUNT(CASE OPP WHEN 'BAR' THEN 1 END)
FROM tablename
WHERE OPP IN ('FOO','BAR') AND date = 'BAZ'

(无论如何,Thilo的GROUP BY方法是更好的通用解决方案.)

编辑:我删除了NVL().我忘记了为什么我从不使用它.

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...