MySQL : query three times on the same table

标签 mysql

我目前正在写一个查询。 从用户、帖子和帖子中的附加信息表 (post_views_info) 中检索信息。

SELECT 
    u.email,
    u.user_nm,
    p.pid,
    p.post_ttl, 
    p.date,
    p.ref_level,
    p.ref_origin,
    p.ref_step,
    date(p.date) = date(now()) AS is_today,
    (SELECT category_path FROM post_category WHERE category_id = p.category_id) as category_full_path,
    (SELECT COUNT(*) FROM post_status_info AS sub_i WHERE sub_i.pid = p.pid AND sub_i.status = 'A') AS recommendCount,
    (SELECT COUNT(*) FROM post_status_info AS sub_i WHERE sub_i.pid = p.pid AND sub_i.status = 'B') AS oppositeCount,
    (SELECT COUNT(*) FROM post_status_info AS sub_i WHERE sub_i.pid = p.pid AND sub_i.status = 'C') AS reportCount
FROM 
    (
        SELECT *
        FROM post as p
        WHERE 
            p.is_enable = 1
        ORDER BY 
            p.ref_origin DESC,
            p.ref_step ASC
    ) as p,
    user AS u
WHERE 
    p.uid = u.uid
ORDER BY 
    ref_origin DESC,
    ref_step ASC

在上面的查询中,我们对同一个表进行了三次查询,以获取帖子“A”、“B”、“C”的数量。

为了解决这个问题,我将查询更改如下。

SELECT 
    u.email,
    u.user_nm,
    p.pid,
    p.post_ttl, 
    p.date,
    p.ref_level,
    p.ref_origin,
    psi.reportCount,
    psi.recommendCount,
    psi.oppositeCount,
    p.ref_step,
    date(p.date) = date(now()) AS is_today,
    (SELECT category_path FROM post_category WHERE category_id =     p.category_id) as category_full_path
FROM 
    user AS u,
    (
        SELECT *
        FROM post as p
        WHERE 
            p.is_enable = 1
        ORDER BY 
            p.ref_origin DESC,
            p.ref_step ASC
        LIMIT 0, 15
    ) as p left join
    (
        SELECT 
                pid, 
                COUNT(if(status = 'A', 1, null)) AS reportCount,
                COUNT(if(status = 'B', 1, null)) AS recommendCount,
                COUNT(if(status = 'C', 1, null)) AS oppositeCount
        FROM post_status_info 
        group by pid
    ) AS psi
on 
    psi.pid = p.pid
WHERE 
    p.uid = u.uid
ORDER BY 
    ref_origin DESC,
    ref_step ASC

我觉得同一张表查询三次会更好。 哪种代码在性能方面更好?

谢谢。

最佳答案

我认为第二种选择在性能方面更有成效。因为在这里我们要执行的查询数量较少。

您也可以使用 CASE 来完成。

SELECT 
u.email,
u.user_nm,
p.pid,
p.post_ttl, 
p.date,
p.ref_level,
p.ref_origin,
p.ref_step,
date(p.date) = date(now()) AS is_today,
(SELECT category_path FROM post_category WHERE category_id = p.category_id) as category_full_path,
(SUM(CASE WHEN sub_i.status = 'A' THEN 1 ELSE 0 END)) AS recommendCount,
(SUM(CASE WHEN sub_i.status = 'B' THEN 1 ELSE 0 END)) AS oppositeCount,
(SUM(CASE WHEN sub_i.status = 'C' THEN 1 ELSE 0 END)) AS reportCount
FROM 
(
    SELECT *
    FROM post as p
    WHERE 
        p.is_enable = 1
    ORDER BY 
        p.ref_origin DESC,
        p.ref_step ASC
) as p,
INNER JOIN user AS u ON u.uid = p.uid
INNER JOIN post_status_info as sub_i ON p.pid = sub_i.pid
GROUP BY p.pid
ORDER BY 
ref_origin DESC,
ref_step ASC

关于MySQL : query three times on the same table,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45630771/

相关文章:

php - PHP 中的 MySQL NULL

MySQL:如何处理定期的大量插入/更新?

通过unix shell脚本Mysql插入语句

php - 如何从第一个选择查询结果集中多次运行选择查询?

php - 从 PHP 脚本执行时 MySQL 临时变量不起作用

mysql - 如何在mysql中将这两个结果合并为一个?

java - SSH 连接到 MySQL

mysql - 在 mysql 中的 INSERT 查询中为 INT 类型列传递 ''(空),适用于某些配置,但不适用于其他配置

mysql - 如何使用 spring-data-jpa 对具有持久关系的实体执行 native 查询

php - 如果是新的一天,则创建新记录,否则更新重复键