Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Laravel MySQL how to order results in the same order as in whereIn clause

I have two queries, the first one gives me an array of ids, that is in a specific order. Then that array of ids I pass it to the second query like so:

 Operation::whereIn('id', $ids)->get();

But when I output the result of that query, the order has changed, if the array $ids was something like (4,2,6,9) which is the order I wanted the results to be in, the output will give me 2,4,6,9. How can I avoid that?

like image 996
Elaine Marley Avatar asked Oct 03 '14 09:10

Elaine Marley


2 Answers

MySQL way of sorting with order same as in where in clause:

$ids; // array of ids
$placeholders = implode(',',array_fill(0, count($ids), '?')); // string for the query

Operation::whereIn('id', $ids)
   ->orderByRaw("field(id,{$placeholders})", $ids)->get();
like image 77
Jarek Tkaczyk Avatar answered Oct 22 '22 23:10

Jarek Tkaczyk


You can do

$idsImploded = implode(',',$ids);
Operation::whereIn('id', $ids)->orderByRaw("FIND_IN_SET('id','$idsImploded')")->get();

It's a problem where MySql doesn't return the result in the order you specify them, so you need to reorder them after that.

A similar solution can be found here: avoid Sorting by the MYSQL IN Keyword

like image 45
Yasen Slavov Avatar answered Oct 23 '22 01:10

Yasen Slavov