How do I specify the parent query field from within a subquery in MySQL?
For Example:
I have written a basic Bulletin Board type program in PHP.
在数据库中,每个帖子包含:id(PK)和parent_id(父帖子的id).如果帖子本身是父项,则其父项id设置为0.
我正在try 编写一个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作为id_tmp,然后在子查询中引用它,但是如果我还想返回id并保留"id"作为列名,那么我必须执行一个查询,返回两个具有相同数据的列(在我看来这很混乱)
$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";
这种混乱的方式很好,但我觉得有机会在这里学到一些东西,所以我想我应该发布这个问题.