where(['user_id' => $user_id]) ->where('id', '!=', $order_main_id) ->where(function ($query){ $query->whereIn('state', [OrderMain::ORDER_STATE_COMPLETE,OrderMain::ORDER_STATE_EVALUATED,OrderMain::ORDER_STATE_UNREFUND]) ->orWhereIn('dm_state', [OrderMain::ORDER_STATE_UNTAKE,OrderMain::ORDER_STATE_DELIVERY]); }) ->exists(); return !$exist; } /** * 根据用户的openid更新unionid信息 * 如果没有找到用户,则不做任何处理 * @param $openid * @param $unionid * @return array */ public function saveUserUnionid($openid,$unionid) { $result = [ 'status' => false, 'msg' => '用户不存在或者已存在相同unionid' ]; // 查询用户是否存在 $userinfo = Users::select('id','unionid')->where('openid',$openid)->first(); if($userinfo && $userinfo->unionid != $unionid){ $userinfo->unionid = $unionid; if($res = $userinfo->save()){ $result['status'] = true; $result['msg'] = '更改用户unionid信息成功'; $result['res'] = $res; }else{ $result['msg'] = '更改用户unionid信息失败'; } } return $result; } /** * @inheritDoc */ public function isStoreFirstOrderToday($user_id, $store_id, $current_order_id, $limit_amount = 3) { return !Order::query() ->where(['user_id' => $user_id, 'store_id' => $store_id]) ->whereIn('dm_state', [OrderMain::ORDER_STATE_UNTAKE,OrderMain::ORDER_STATE_DELIVERY]) ->where('time_add', '>=', date('Y-m-d 00:00:00')) ->where('time_add', '<=', date('Y-m-d 23:59:59')) ->where('money', '>=', $limit_amount) ->where('id', '!=', $current_order_id) ->exists(); } }