Welcome to WuJiGu Developer Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
1.1k views
in Technique[技术] by (71.8m points)

arrays - Merge two Eloquent Collections and remove all duplicates.

I have two arrays, $user_roles and $global_roles. I want to make a new array, let's call it $available_roles, where it can be equated as the items in $global_roles less the items in the $user_roles

I have the following code to do it to a normal array. $available_roles = array_unique(array_merge($global_roles, $user_roles), SORT_REGULAR);

This is proving to be problematic due to the fact that Laravel does not use traditional arrays when one executes a query, it uses Eloquent Collections.

What other ideas do you guys have?

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Answer

0 votes
by (71.8m points)

This is fairly simple. You can use the Collection's merge method:

$available_roles = $global_roles->merge($user_roles);

Because merge internally uses an associative array (dictionary) that uses the id as key, this should automatically remove duplicates.

Anyways though, you can remove duplicates in a collection using unique:

$uniqueCollection = $collection->unique();

Now that was for merging what you're actually are looking for is the difference between two collections. You can do this in two ways:

$available_roles = $user_roles->diff($global_roles);

or

$available_roles = $global_roles->except($user_roles->modelKeys());

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome to WuJiGu Developer Q&A Community for programmer and developer-Open, Learning and Share
...