getChannelIds(); foreach ($channel_ids as $channel_id) { $key = sprintf('channel:setting:%s', $channel_id); $hkey = 'title'; $count = $this->getChannelOfficialAccountCount($channel_id); if ($count > 1) { Redis::hDel($key, $hkey); } else if ($count == 1) { $official_account = $this->getOfficialAccount($channel_id); Redis::hSet($key, $hkey, $official_account->nickname); } } } private function getChannelIds() { return OfficialAccount::select('distribution_channel_id')->groupBy('distribution_channel_id')->pluck('distribution_channel_id')->all(); } private function getOfficialAccount(int $channel_id) { return OfficialAccount::where('distribution_channel_id', $channel_id)->first(); } private function getChannelOfficialAccountCount(int $channel_id) { return OfficialAccount::where('distribution_channel_id', $channel_id)->count(); } }