相关疑难解决方法(0)

如何在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";
Run Code Online (Sandbox Code Playgroud)

棘手的部分是第一个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";
Run Code Online (Sandbox Code Playgroud)

凌乱的方式很好,但我觉得有机会在这里学到一些东西,所以我想我会发布这个问题.

php mysql subquery parent-child

51
推荐指数
2
解决办法
7万
查看次数

标签 统计

mysql ×1

parent-child ×1

php ×1

subquery ×1