获取连续签到起始日期

 根据用户信息及签到日期,获取用户起始的签到天数,可以根据当天是否签到获取连签天数

$signinTables = getAllSignTable();
// 当前月表
$curTable = 'signinlog'.date('Ym');
$signStartDate = '';
foreach ($signinTables as $table) {
    // 应签天数
    $needDays = $curTable == $table ? ((int)date('d') -1) : (int)date('t');
    $monthFirstDay = date('Y-m-01',strtotime(substr($table,6).'01'));
    $endDay = $curTable == $table ? date('Y-m-d',strtotime('-1 day')) : date('Y-m-t',strtotime($monthFirstDay));
    // 该月累计签到天数
    $sql = " select signdate from {$table} where userid={$userid}";
    $result = $actDb->getAll($sql);
    if ($needDays > count($result)) {
        if (empty($result)) {
            break;
        }
        $signDayArr = array_column($result,'signdate');
        for($i = $endDay; $i >= $monthFirstDay; $i = date('Y-m-d',strtotime('-1 day',strtotime($i)))) {
            if (!in_array($i,$signDayArr)) {
                break 2;
            }
            $signStartDate = $i;
        }
    } else {
        $signStartDate = date('Y-m-d',strtotime(substr($table,6).'01'));
    }
}
echo $signStartDate;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值