'integer', 'coupon_template_id' => 'integer', 'send_count' => 'integer', 'receive_count' => 'integer', 'left_count' => 'integer', 'item_count' => 'integer', 'appoint_group' => 'integer', 'claim_rule' => 'integer', 'appoint_city_id' => 'integer', 'validity_time_type' => 'integer','status' => 'integer']; const string CREATED_AT = 'create_time'; const string UPDATED_AT = 'update_time'; /** * @param int $id * @return CouponDispenseLog|CouponDispenseLog[]|\Hyperf\Database\Model\Model|null */ public function getInfoById(int $id): \Hyperf\Database\Model\Model|CouponDispenseLog|array|null { return $this->find($id); } /** * @param array $ids * @return array */ public function getListByIds(array $ids): array { return $this->whereIn('id',$ids)->get()->toArray(); } /** * @param int $id * @param int $receiveCount * @return int */ public function updateReceiveCountById(int $id,int $receiveCount): int { return $this->where('id', $id)->increment('receive_count' , $receiveCount); } /** * @return array */ public function getNoReceiveCount(): array { return $this ->where('claim_rule',CouponCode::DISPENSE_CLAIM_RULE_HOME_POPUPS) ->whereColumn('total_count','!=','receive_count') ->where('appoint_group',CouponCode::DISPENSE_APPOINT_GROUP_ALL_PEOPLE) ->where('status',CouponCode::DISPENSE_VALIDITY) ->pluck('id') ->toArray(); } /** * @param array $ids * @return Collection */ public function getInfoByIds(array $ids) { return $this->whereIn('id',$ids)->get(); } }