Search

Laravel Collection Public API: unique

November 30, 2016 —John Koster

unique($key = null)

The unique method can be used to get all the unique items in the collection. It accepts an option $key which can be used to further restrict which items are returned. The unique method returns a new instance of Collection with the items it determined to be unique.

The following code example shows the basic usage of the unique method:

1<?php
2 
3use Illuminate\Support\Collection;
4 
5// Create a new collection instance.
6$collection = new Collection([
7 'a', 'A', 'b', 'c', 1, 1, 2, 3
8]);
9 
10// Get all unique items.
11$uniqueItems = $collection->unique();

After the above code executes, the $uniqueItems variable will be an instance of Collection and will have a value similar to the following output. It should be noted that the unique method is case sensitive.

1object(Illuminate\Support\Collection)[134]
2 protected 'items' =>
3 array (size=7)
4 0 => string 'a' (length=1)
5 1 => string 'A' (length=1)
6 2 => string 'b' (length=1)
7 3 => string 'c' (length=1)
8 4 => int 1
9 6 => int 2
10 7 => int 3

The following code sample demonstrates how to use the unique method to get all the unique items in a collection based on a given property of the collection's items (in this example it is the name of hypothetical users):

1<?php
2 
3use Illuminate\Support\Collection;
4 
5// Create a new collection instance.
6$collection = new Collection([
7 ['id' => 5, 'name' => 'Jane', 'sex' => 'female'],
8 ['id' => 6, 'name' => 'Bill', 'sex' => 'male'],
9 ['id' => 7, 'name' => 'Sarah', 'sex' => 'female'],
10 ['id' => 8, 'name' => 'Sarah', 'sex' => 'female']
11]);
12 
13// Get all unique items.
14$uniqueItems = $collection->unique('name');

After the above code has finished executing the $uniqueItems variable will be an instance of Collection and will have a value similar to the following output:

1object(Illuminate\Support\Collection)[137]
2 protected 'items' =>
3 array (size=3)
4 0 =>
5 array (size=3)
6 'id' => int 5
7 'name' => string 'Jane' (length=4)
8 'sex' => string 'female' (length=6)
9 1 =>
10 array (size=3)
11 'id' => int 6
12 'name' => string 'Bill' (length=4)
13 'sex' => string 'male' (length=4)
14 2 =>
15 array (size=3)
16 'id' => int 7
17 'name' => string 'Sarah' (length=5)
18 'sex' => string 'female' (length=6)

The provided $key can also be a callback function that accepts one argument. The argument will be the item from the collection. The callback function should return the value the unique method uses to determine uniqueness. The following example is similar to the first example in this section, but will effectively perform a case-insensitive uniqueness check:

1<?php
2 
3use Illuminate\Support\Collection;
4 
5// Create a new collection instance.
6$collection = new Collection([
7 'a', 'A', 'b', 'c', 1, 1, 2, 3
8]);
9 
10// Get all unique items.
11$uniqueItems = $collection->unique(function($item) {
12 return strtolower($item);
13});

After the above code has been ran, the $uniqueItems variable will be an instance of Collection and contain a value similar to the following output:

1object(Illuminate\Support\Collection)[137]
2 protected 'items' =>
3 array (size=6)
4 0 => string 'a' (length=1)
5 2 => string 'b' (length=1)
6 3 => string 'c' (length=1)
7 4 => int 1
8 6 => int 2
9 7 => int 3

Some absolutely amazing
people

The following amazing people help support this site and my open source projects ♥️
If you're interesting in supporting my work and want to show up on this list, check out my GitHub Sponsors Profile.