php – 如何在mySQL的子查询中指定父查询字段?

有没有办法从mySQL的子查询中指定父查询字段?

例如:
我在PHP中编写了一个基本的公告板类型程序。

在数据库中,每个帖子包含:id(PK)和parent_id(父帖的id)。如果帖子本身是父级,则其parent_id设置为0。

我试图写一个mySQL查询,将找到每个父帖子和父的孩子的数量。

$query = "SELECT id, (
      SELECT COUNT(1) 
      FROM post_table 
      WHERE parent_id = id
) as num_children
FROM post_table
WHERE parent_id = 0";

棘手的部分是,第一个id不知道它应该引用在子查询之外的第二个id。我知道我可以做SELECT id AS id_tmp然后在子查询里面引用它,但是如果我还要返回id并保持“id”作为列名称,那么我将不得不做一个查询返回我2列有相同的数据(这看起来很麻烦我)

$query = "SELECT id, id AS id_tmp, 
            (SELECT COUNT(1)
            FROM post_table
            WHERE parent_id = id_tmp) as num_children
         FROM post_table
         WHERE parent_id = 0";

凌乱的方式工作正常,但我觉得有机会在这里学习的东西,所以我想我会发布的问题。

最佳答案
怎么样:

$query = "SELECT p1.id, 
                 (SELECT COUNT(1) 
                    FROM post_table p2 
                   WHERE p2.parent_id = p1.id) as num_children
            FROM post_table p1
           WHERE p1.parent_id = 0";

或者如果在p1.id上添加别名,您可能会说:

$query = "SELECT p1.id as p1_id, 
                 (SELECT COUNT(1) 
                    FROM post_table p2 
                   WHERE p2.parent_id = p1.id) as num_children
            FROM post_table p1
           WHERE p1.parent_id = 0";

转载注明原文:php – 如何在mySQL的子查询中指定父查询字段? - 代码日志