在我的项目中,我需要用户订阅的计划未过期。当用户订阅计划时,它将输入表 usersubscription ,其结构如下所示:
id user_id plan_id subscribed_on
用于存储计划详细信息的表是 subscription_plans :
id plan days_limit discounted_rate added_on status rate
1 PlanJ 30 240 1403094260 1 245.00
此表格将包含项目中订阅计划的详细信息。视频可以是一个或多个计划的一部分。如果某个视频符合规划,则会将其存储在数据库 subscribed_videos 中。
id plan_id videoid
此外,计划也可以成为另一个计划的一部分。这是假设有计划说A和B.视频1是计划B的一部分,并计划包含计划B(相关计划)。因此,如果用户订阅了计划A,则计划B中的视频将可用于他。关联计划的表格是 subscription_groups 。结构在下面分享:
id plan_id assosiated_plan_id added_on
我需要检查用户是否订阅了未过期的计划(包含所选视频)(即,它将在 subscribed_on + days_limit 天过期)。我现在使用的当前查询是
select u.id,sp.days_limit from usersubscription as u INNER JOIN subscription_plans as
sp ON sp.id=u.plan_id where (plan_id IN ( ( SELECT DISTINCT plan_id FROM subscribed_videos
sv where sv.videoid = 57 ) ) OR id IN ( SELECT DISTINCT assosiated_plan_id AS plan_id FROM
subscription_groups sg JOIN subscribed_videos sv ON sv.plan_id = sg.plan_id WHERE
sv.videoid = 57 ) ) and u.user_id=1 AND DATE_ADD(FROM_UNIXTIME(u.subscribed_on), INTERVAL
sp.days_limit DAY) > NOW()
这将检查id为1的用户是否订阅了包含id为57的视频的任何计划(主计划或相关计划)。我将日期保存为整数(unix timestamp)。
任何人都可以帮我找到解决方案吗?请查看此SQL FIDDLE
提前致谢