PostgreSQL JOIN with array type with array elements order, how to implement?
Solution 1
SELECT t.*
FROM unnest(ARRAY[1,2,3,2,3,5]) item_id
LEFT JOIN items t on t.id=item_id
The above query select items from items
table with ids: 1,2,3,2,3,5 in that order.
Solution 2
Probably normalizing your table would be the best advice I can give you.
The int_array contrib module has an idx function that will give you the int's index position in the array. Also there is an idx function on the snippets wiki that works for array's of any data types.
SELECT i.*, idx(id_items, i.id) AS idx
FROM some_chosen_data_in_order s
JOIN items i ON i.id = ANY(s.id_items)
ORDER BY idx(id_items, i.id)
Solution 3
select distinct on (some_chosen_data_in_order.id)
some_chosen_data_in_order.*,
array_to_json( array_agg(row_to_json( items))
over ( partition by some_chosen_data_in_order.id ))
from some_chosen_data_in_order
left join items on items.id = any (some_chosen_data_in_order.id_items)
Solution 4
SELECT I.* FROM items AS I
WHERE I.id IN (SELECT UNNEST(id_items) FROM some_chosen_data_in_order
(ARRAY[SELECT S.id_items FROM some_chosen_data_in_order WHERE id = ?])
Adiasz
Mainly backend developer, Laravel, Wordpress, sql, api. Skilled also in frontend.
Updated on July 08, 2022Comments
-
Adiasz almost 2 years
I have two tables in database:
CREATE TABLE items( id SERIAL PRIMARY KEY, ... some other fields );
This table contains come data row with unique ID.
CREATE TABLE some_chosen_data_in_order( id SERIAL PRIMARY KEY, id_items INTEGER[], );
This table contains array type field. Each row contains values of IDs from table
items
in specific order. For example:{2,4,233,5}
.Now, I want to get data from table
items
for chosen row from tablesome_chosen_data_in_order
with order for elements in array type.My attempt was JOIN:
SELECT I.* FROM items AS I JOIN some_chosen_data_in_order AS S ON I.id = ANY(S.id_items) WHERE S.id = ?
Second attempt was subquery like:
SELECT I.* FROM items AS I WHERE I.id = ANY (ARRAY[SELECT S.id_items FROM some_chosen_data_in_order WHERE id = ?])
But none of them keep IDs in the same order as in array field. Could you help me, how to get data from
items
table with correspond with array IDs order fromsome_chosen_data_in_order
table for specific row?