扫码关注官方订阅号
要做一个类似的功能:如设置一个日期每月20号,在这日期的前几天来提醒用户该送礼了。日期可以设置为几月几日、也可为每月几号等。提醒时间可以是当天提醒、前一周提醒等?
这种功能后台数据库该如何设计,需要几张表? 消息推送功能有了,如何检测什么时候推送? 后台写个定时任务来不断运行?
欢迎选择我的课程,让我们一起见证您的进步~~
两个定时任务,三个表1.礼物表,里面有什么时候发送字段,是否发送字段2.消息表,是否发送,发送的是什么,发送给谁3.消息人表,每个人的消息这提取任务一,扫描任务表,如果没发送且到时间了,插入一条数据到消息表任务二,扫描消息表,有消息了就根据系统发送消息,,,,,他是个公共表,不一定就用来发礼物
需要判断应用环境,在web访问中,再用户访问时去做判断.
需要几张表看你们具体业务需求,业务需求不复杂的一张信息表足矣。你要是设置定时的肯定需要设置脚本的。或者你用第三方推送极光推送都可以的
数据字典1 用户信息表用字段is_accept 来存放用户是否开启消息提示
2 建立消息推送配置表id 主键task_obj扩展字段title 标题content 内容on_time 结束时间status 平台是否开启消息提示days 提前几天提醒(这个字段也可以给用户设定,存在用户信息表,让用户来决定什么时候提示他)tips 推送几次interval_time 推送间隔(同一个用户多久推送一次)3 消息推送日志表id 主键iduid 用户idtid 消息配置idon_time 发送推送时间
4 php业务逻辑 //获取要用户表is_accept为1的所有用户循环
foreach{ //获取推送配置信息表 //判断用户是否已推送, //判断 当前时间-用户上次推送时间>=配置间隔时间 //判断是否已达到最大推送次数 //写入推送记录表 }
5 实现 如果是linux系统 建议使用系统命令curl windows系统 建议自己写进程守护,或者使用urlcron
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
两个定时任务,三个表
1.礼物表,里面有什么时候发送字段,是否发送字段
2.消息表,是否发送,发送的是什么,发送给谁
3.消息人表,每个人的消息这提取
任务一,扫描任务表,如果没发送且到时间了,插入一条数据到消息表
任务二,扫描消息表,有消息了就根据系统发送消息,,,,,他是个公共表,不一定就用来发礼物
需要判断应用环境,在web访问中,再用户访问时去做判断.
需要几张表看你们具体业务需求,业务需求不复杂的一张信息表足矣。你要是设置定时的肯定需要设置脚本的。或者你用第三方推送极光推送都可以的
数据字典
1 用户信息表用字段is_accept 来存放用户是否开启消息提示
2 建立消息推送配置表
id 主键
task_obj扩展字段
title 标题
content 内容
on_time 结束时间
status 平台是否开启消息提示
days 提前几天提醒(这个字段也可以给用户设定,存在用户信息表,让用户来决定什么时候提示他)
tips 推送几次
interval_time 推送间隔(同一个用户多久推送一次)
3 消息推送日志表
id 主键id
uid 用户id
tid 消息配置id
on_time 发送推送时间
4 php业务逻辑
//获取要用户表is_accept为1的所有用户循环
5 实现
如果是linux系统 建议使用系统命令curl
windows系统 建议自己写进程守护,或者使用urlcron