gpt4 book ai didi

mysql - 为什么这个 MySQL 查询的结果会相乘?

转载 作者:可可西里 更新时间:2023-11-01 07:49:25 24 4
gpt4 key购买 nike

SELECT user_id,
SUM(COALESCE(point_points, 0)) AS total_points,
SUM(
CASE
WHEN point_date > '$this_month'
THEN point_points
ELSE 0
END) AS month_points,
COUNT(DISTINCT c_id) AS num_comments,
COUNT(DISTINCT rant_id) AS live_submissions
FROM users
LEFT JOIN points
ON users.user_id = points.point_userid
LEFT JOIN comments
ON
(
c_userid = user_id
)
LEFT JOIN rants
ON
(
rant_poster = user_id
AND rant_status = 1
)
WHERE user_id = $id
GROUP BY user_id

基本上 live_submissionsnum_comments 变量显示正确的结果,而 total_pointsmonth_points 显示产品 month_points/total_pointslive_submissionsnum_comments。知道为什么会这样吗?

最佳答案

这叫做 Cartesian Product .当您将表连接在一起时,默认结果是连接条件为真的行的每个排列。您使用 JOIN 条件来限制这些排列。

但由于您将多个表连接到 users,结果包括每个匹配表的每个排列。例如,points 中的每个匹配行在 comments 中的每个匹配行中重复,并且这些中的每一个都再次相乘,在 rants 中的每个匹配行中重复>。

您可以像现在一样使用 COUNT(DISTINCT c_id) 部分补偿这一点,但是 DISTINCT 是必需的,只是因为每个 c_id 有多行。除非您将其应用于唯一值,否则它不起作用。此补救措施不适用于 SUM() 表达式。

基本上,您试图在一个查询中进行太多计算。您需要将其拆分为单独的查询以使其可靠。然后你也可以去掉 DISTINCT 修饰符。

SELECT u.user_id, SUM(COALESCE(p.point_points, 0)) AS total_points, 
SUM( CASE WHEN p.point_date > '$this_month' THEN p.point_points ELSE 0 END ) AS month_points
FROM users u LEFT JOIN points p
ON u.user_id = p.point_userid
WHERE u.user_id = $id
GROUP BY u.user_id;

SELECT user_id, COUNT(c.c_id) as num_comments,
FROM users u LEFT JOIN comments c
ON (c.c_userid = u.user_id)
WHERE u.user_id = $id
GROUP BY u.user_id;

SELECT u.user_id, COUNT(r.rant_id) as live_submissions
FROM users u LEFT JOIN rants r
ON (r.rant_poster = u.user_id AND r.rant_status = 1)
WHERE u.user_id = $id
GROUP BY u.user_id;

您不应该尝试在单个查询中执行所有这三个操作。

关于mysql - 为什么这个 MySQL 查询的结果会相乘?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/707833/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com