如何在 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";
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)