Odmianą rozwiązania Neila, która nie wymaga rozszerzenia jest:
create table friendz (
from_id int,
to_id int
);
create unique index ifriendz on friendz(greatest(from_id,to_id), least(from_id,to_id));
Rozwiązanie Neila pozwala jednak na użycie dowolnej liczby kolumn.
Oboje polegamy na użyciu wyrażeń do budowy indeksu, który jest udokumentowanyhttps://www.postgresql.org/docs/current/indexes-expressional.html