The usual way of setting a foreign key constraint is to choose which table the foreign key will point to.
I'm having a polymorphic relation between 1 table and a set of table.
That means that this table will have a relation with one of those tables in the set.
eg.
images: person_id, person_type
subordinates: id, col1, col2...col9
products: id, colA, colB...colZ
In the above example, if person_type is "subordinates" then person_id should be a foreign key to subordinates.id and the same goes with products.
So I wonder, is it possible to have a foreign key to one of many tables, or do you have to specifically set which table it points to when you assign one.
This question is for both MySQL and PostgreSQL.
Thanks
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…