大佬教程收集整理的这篇文章主要介绍了php-从其他表中选择带有条件规则(计数)的数据,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我的数据库中有这些结构:
Table coupon
coupon_id , code, max_used
Table coupon_history
coupon_history_id, coupon_id, used_date
我可以在“ coupon_history”获得不超过总历史记录的优惠券数据吗?
我被困在这里.我需要获取一个coupon_code.请帮我.
解决方法:
尝试像这样使用JOIN和IN:
SELECT cc.* FROM coupon cc
WHERE cc.coupon_id IN
(
SELECT c.coupon_id FROM Coupon c
LEFT JOIN
( SELECT coupon_id, COUNT(coupon_id) maxUsed
FROM coupon_history GROUP BY coupon_id
) ch
ON c.Coupon_id = ch.Coupon_id
WHERE c.max_used > ch.maxUsed
OR ch.maxUsed IS NULL
);
或者,您可以像这样简单地使用JOIN:
SELECT cc.* FROM coupon cc
JOIN
(
SELECT c.coupon_id FROM Coupon c
LEFT JOIN
( SELECT coupon_id, COUNT(coupon_id) maxUsed
FROM coupon_history GROUP BY coupon_id
) ch
ON c.Coupon_id = ch.Coupon_id
WHERE c.max_used > ch.maxUsed
OR ch.maxUsed IS NULL
) c ON cc.coupon_id = c.coupon_id;
编辑:关于您的second requirement
试试这个查询:
SELECT cc.*,c.@R_302_10586@lUsed FROM coupon cc
JOIN
(
SELECT c.coupon_id,@R_302_10586@lUsed FROM Coupon c
LEFT JOIN
( SELECT coupon_id, COUNT(coupon_id) @R_302_10586@lUsed
FROM coupon_history GROUP BY coupon_id
) ch
ON c.Coupon_id = ch.Coupon_id
WHERE c.max_used > ch.@R_302_10586@lUsed
OR ch.@R_302_10586@lUsed IS NULL
) c ON cc.coupon_id = c.coupon_id;
以上是大佬教程为你收集整理的php-从其他表中选择带有条件规则(计数)的数据全部内容,希望文章能够帮你解决php-从其他表中选择带有条件规则(计数)的数据所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。