php mysql 子查询_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";

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值