MySQL从多个表与LEFT JOIN多个

马库斯

我想展示所有用户的结论。

我有3张桌子。

餐桌贴

post_id(index)     user_id
1                  1
2                  3
3                  3
4                  4

桌子照片

photo_id(index)     user_id
1                   2
2                   4
3                   1
4                   1

桌面视频

photo_id(index)     user_id
1                   4
2                   4
3                   3
4                   3

表中的用户

user_id(index)     user_name
1                  mark
2                  tommy
3                  john
4                  james

实际上,每个表有4行以上。

我想要这样的结果。

id     name      post    photo   videos
1      mark      1       2       0
2      tommy     0       1       0
3      john      2       0       2
4      james     1       1       2
5      ..        ..      ..      ..

下面的代码是可以正常运行但非常慢的SQL,如果您能帮助我如何使用LEFT JOIN,将不胜感激谢谢。

的SQL

"select user.*, 
(select count(*) from post where post.userid = user.userid) postCount,
(select count(*) from photo where photo.userid = user.userid) photoCount,
(select count(*) from video where video .userid = user.userid) videoCount
from user order by user.id"

(或按我想要的ORDER BY postCount,photoCount或videoCount ASC或DESC)

我之前做过研究,但没有任何帮助。

价钱
    SELECT u.user_id, 
           u.user_name,
           COUNT(DISTINCT p.post_id) AS `postCount`,
           COUNT(DISTINCT ph.photo_id) AS `photoCount`,
           COUNT(DISTINCT v.video_id) AS `videoCount`
      FROM user u
 LEFT JOIN post p
        ON p.user_id = u.user_id
 LEFT JOIN photo ph
        ON ph.user_id = u.user_id
 LEFT JOIN video v
        ON v.user_id = u.user_id
  GROUP BY u.user_id
  ORDER BY postCount;

现场演示

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

MySQL LEFT JOIN无法使用多个表

来自分类Dev

多个表中的多个 LEFT JOIN

来自分类Dev

如何使用 LEFT JOIN 连接多个 mySQL 表?

来自分类Dev

MySQL多个LEFT JOIN返回重复的行

来自分类Dev

MYSQL 使用 join 查询多个表

来自分类Dev

MySQL查询-多个JOIN

来自分类Dev

如何优化多个LEFT JOIN

来自分类Dev

多个LEFT JOIN-“左”表是什么?

来自分类Dev

使用LEFT JOIN和UNION合并多个表

来自分类Dev

存在null时如何查询多个Left Join表

来自分类Dev

MySQL-如何改善使用多个LEFT JOIN的复杂查询

来自分类Dev

MySql LEFT连接多个具有相同ID或名称的表

来自分类Dev

MySql LEFT连接多个具有相同ID或名称的表

来自分类Dev

Rails Join与哈希多个表

来自分类Dev

.Join .Group Lambda多个表

来自分类Dev

多个表之间的JOIN功能

来自分类Dev

在第二个表中正确显示具有多个匹配项的mySQL LEFT JOIN

来自分类Dev

在MySQL中优化多个JOIN

来自分类Dev

MySQL:JOIN多个值的总和

来自分类Dev

MySQL JOIN QUERY与多个条款

来自分类Dev

多个 foreach 循环与 mysql join

来自分类Dev

MySQL JOIN 3表使用多个列/键

来自分类Dev

在多个表上的MYSQL JOIN不返回结果

来自分类Dev

在MySQL中使用JOIN从多个表中删除行

来自分类Dev

MySQL JOIN为PHP中的多个HTML表安排结果

来自分类Dev

是多个查询还是LEFT JOIN更快?

来自分类Dev

Nhibernate Left Join 中的多个条件

来自分类Dev

PostgreSQL:具有多个条件的多个LEFT JOIN

来自分类Dev

SQL LEFT JOIN多个表,包括每个联接到1个表的链接