我有一些表基本上如下:
TBL_USER
user_id - number
user_name - varchar
TBL_STUFF
stuff_id - number
stuff_user_id - number
我想查询所有用户信息,包括他们拥有的“东西”的数量。我正在尝试这样的事情:
select user_id, user_name, count(stuff_id)
from tbl_user
left outer join tbl_stuff on stuff_user_id = user_id
where user_id = 5;
但是我收到的错误是“不是单组组功能”
还有其他方法我应该这样做吗?
答案 0 :(得分:8)
好吧,你错过了小组的功能; - )
试试这个:
select user_id, user_name, count(stuff_id)
from tbl_user left outer join tbl_stuff on stuff_user_id = user_id
where user_id = 5
group by user_id, user_name;
最后一行是group by
子句,它告诉Oracle使用相同的user_id和user_name组合计算所有行。
答案 1 :(得分:7)
你也可以这样做:
select
user_id,
user_name,
(
SELECT
COUNT(*)
FROM
tbl_stuff
WHERE
stuff_user_id = tbl_user.user_id
) AS StuffCount,
from
tbl_user
where
user_id = 5;
答案 2 :(得分:1)
您的一条评论声明您不希望包含GROUP BY
子句中的所有字段。
@Arion发布了一个相关子查询重新因子,它给出了相同的值。
以下查询使用标准(不相关)子查询(内联视图)。这是因为使用此内联视图结构可以经常执行相关子查询等效项。但是,因为我发现它们更容易维护。
WITH
stuff_count
AS
(
SELECT
stuff_user_id AS user_id,
COUNT(*) AS val
FROM
tbl_stuff
GROUP BY
stuff_user_id
)
SELECT
tbl_user.user_id,
tbl_user.user_name,
stuff_count.val
FROM
tbl_user
LEFT JOIN
stuff_count
ON stuff_count.user_id = tbl_user.user_id
WHERE
tbl_user.user_id = 5;
注意: 生成计划时,它只运行user_id所需的子查询,不整个表;)