2

这就是我想要做的。我有一个包含重复行的用户评估表。我希望只DISTINCT为每个用户获取值。

在下表的示例中。如果只有 user_id 1 和 50 属于特定位置,则只有每个用户的唯一 video_id 应作为COUNT. 用户 1 传递了视频 1、2 和 1。所以应该只有 2 条记录,而用户 50 传递了视频 2。所以这个位置的总数是 3。我想我需要DISTINCT's在查询中有两个,但不是确定如何做到这一点。

+-----+----------+----------+
| id  | video_id | user_id  |
+-----+----------+----------+
| 1   |       1  |        1 |
| 2   |       2  |       50 |
| 3   |       1  |      115 |
| 4   |       2  |       25 |
| 5   |       2  |        1 |
| 6   |       6  |       98 |
| 7   |       1  |        1 |
+-----+----------+----------+

这就是我当前查询的样子。

$stmt2 = $dbConn->prepare("SELECT COUNT(DISTINCT user_assessment.id)
FROM user_assessment
LEFT JOIN user ON user_assessment.user_id = user.id
WHERE user.location = '$location'");
$stmt2->execute();
$stmt2->bind_result($video_count);
$stmt2->fetch();
$stmt2->close();

因此,我的查询返回该特定位置的所有计数,但它不会忽略来自每个特定用户的非唯一结果。

希望这是有道理的,感谢您的帮助。

4

2 回答 2

6
SELECT COUNT(DISTINCT ua.video_id, ua.user_id)
FROM user_assessment ua
INNER JOIN user ON ua.user_id = user.id
WHERE user.location = '$location'

你可以在里面写很多东西,COUNT所以不要犹豫,把你真正想要的东西放进去。这将给出不同情侣的数量,(video_id, user_id)如果我理解正确的话,这就是你想要的。

于 2012-10-16T15:58:19.110 回答
1

下面的查询加入了一个子查询,该查询为每个用户获取不同的视频。然后,主查询对这些数字进行求和,以获得该位置的视频总数。

SELECT 
  SUM(video_count)
FROM 
  user u
  INNER JOIN 
  ( SELECT
      ua.user_id,
      COUNT(DISTINCT video_id) as video_count
    FROM
      user_assessment ua
    GROUP BY
      ua.user_id) uav on uav.user_id = u.user_id
WHERE 
  u.location = '$location'

请注意,由于您已经使用了绑定,因此您还可以传入$location绑定参数。我把这个留给你,因为它不是问题的一部分。;-)

于 2012-10-16T15:51:31.773 回答