【发布时间】:2025-11-24 05:30:02
【问题描述】:
如何在 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";
乱七八糟的方法很好用,但我觉得有机会在这里学习一些东西,所以我想我会发布这个问题。
【问题讨论】:
标签: php mysql subquery parent-child