Нахождение массива идентификаторов при сохранении порядка с Rails и PostGreSQL - PullRequest
0 голосов
/ 26 октября 2010

У меня есть массив идентификаторов объектов, которые я хочу получить из базы данных, но PostGreSQL возвращает их, отсортированные по идентификаторам:

Users.find([4, 1, 3])
=> [User 1, User 3, User 4]

Я знаю, что могу отсортировать их так:

ids = [4, 3, 1]
r = Users.find(ids)
users = ids.map{|id| r.detect{|each| each.id == id}}

Но не лучше ли мне сделать это с базой данных?Я знаю, что MySQL имеет опцию «поля».Есть ли в PostGreSQL что-то эквивалентное?

Спасибо,

Кевин

1 Ответ

2 голосов
/ 26 октября 2010

Эта функция будет имитировать функцию из MySQL

CREATE OR REPLACE FUNCTION field(anyelement, anyarray) RETURNS integer AS 
$body$
  SELECT COALESCE((
    SELECT i
    FROM generate_series(array_lower($2, 1), array_upper($2, 1)) s(i)
    WHERE $2[i] = $1
  ),0);
$body$ LANGUAGE SQL STABLE;

Пример использования:

CREATE TABLE x (id integer);
INSERT INTO x (1),(2),(3);
SELECT * FROM x ORDER BY field(id, ARRAY[3,1,2]);
 id 
----
  3
  1
  2
(3 rows)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...