delete(); } // Otherwise, we get the actual IDs that should be deleted… $allIDs = static::select($key)->get()->pluck($key)->all(); $whereInIDs = array_diff($allIDs, $ids); // …and see if we can delete them instead. if (count($whereInIDs) < 65535) { return static::whereIn($key, $whereInIDs)->delete(); } // If that's not possible (i.e. this array has more than 65535 elements, too) // then we'll delete chunk by chunk. return static::deleteByChunk($ids, $key); } /** * Delete records chunk by chunk. * * @param array $ids The array of record IDs to delete * @param string $key Name of the primary key * @param int $chunkSize Size of each chunk. Defaults to 2^16-1 (65535) */ public static function deleteByChunk(array $ids, $key = 'id', $chunkSize = 65535) { DB::beginTransaction(); try { foreach (array_chunk($ids, 65535) as $chunk) { static::whereIn($key, $chunk)->delete(); } DB::commit(); } catch (Exception $e) { DB::rollBack(); } } }