I am attempting to create a DB for my app and one thing I'd like to find the best way of doing is creating a one-to-many relationship between my Users
and Items
tables.
I know I can make a third table, ReviewedItems
, and have the columns be a User
id and an Item
id, but I'd like to know if it's possible to make a column in Users
, let's say reviewedItems
, which is an integer array containing foreign keys to Items
that the User
has reviewed.
If PostgreSQL can do this, please let me know! If not, I'll just go down my third table route.
No, this is not possible.
PostgreSQL is a relational DBMS, operating most efficiently on properly normalized data models. Arrays are - by definition, they are ordered sets - not relational data structures and the SQL standard therefore does not support defining foreign keys on array elements, and neither does PostgreSQL.
You can, however, build a perfectly fine database with array elements linking to primary keys in other tables. Those array elements, however, can not be declared to be foreign keys and the DBMS will therefore not maintain referential integrity.