PHP   发布时间:2022-04-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了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;

看看this SQLFiddle demo

编辑:关于您的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;

参见this SQLFiddle

大佬总结

以上是大佬教程为你收集整理的php-从其他表中选择带有条件规则(计数)的数据全部内容,希望文章能够帮你解决php-从其他表中选择带有条件规则(计数)的数据所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: