mysql count php 取值,php – MySQL COUNT()特定条件内的帖子总数?

我一直在想弄清楚我做错了什么,让我解释一下我的

MySQL结构(所以你得到了更好的理解),直到我直接回答这个问题.

我有一个简单的PHP论坛,我在两个表(帖子和主题)中有一个名为’deleted’的列,如果它等于0表示它显示(被认为没有删除/存在)或者它等于1它隐藏(被认为已删除/不存在) – bool / lean.

现在,我正在讨论“特定标准”…我想要使用其id(forum_id)在特定论坛中获得总计数,确保它只计算未删除的帖子(删除= 0)并且它们的父主题也不会被删除(已删除= 0).

列/表名称是不言自明的(如果需要,请参阅下面的工作 – 如果需要).

我尝试了以下(使用’简单’JOIN):

SELECT COUNT(t1.post_id)

FROM forum_posts AS t1, forum_topics AS t2

WHERE t1.forum_id = '{$forum_id}'

AND t1.deleted = 0

AND t1.topic_id = t2.topic_id

AND t2.deleted = 0

LIMIT 1

我也试过这个(使用子查询):

SELECT COUNT(t1.post_id)

FROM forum_posts AS t1

WHERE t1.forum_id = '{$forum_id}'

AND t1.deleted = 0

AND (SELECT deleted

FROM forum_topics

WHERE topic_id = t1.topic_id) = 0

LIMIT 1

但两者都不符合具体标准.

感谢所有帮助! 🙂

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值