Mysql
 sql >> Base de données >  >> RDS >> Mysql

MySQL :deux clés étrangères dans une table faisant référence à une autre table

Et c'est parti :vous avez spécifié les mêmes alias pour les relations.

User:
  relations:
    viewed_by: 
       class: View
       local: user_id
       foreign: viewed_id
       type: many
       foreignType: one
       foreignAlias: viewed

    viewed:
      class: View
      local: user_id
      foreign: viewer_id
      type: many
      foreignType: one
      foreignAlias: viewer

Ou vous configurez l'ensemble de la relation plusieurs-à-plusieurs différemment :

User:
   relations:
     viewed_by: 
       class: User 
       local: viewed_id
       foreign: viewer_id,
       refClass: View
     viewed:
       class: User
       local:viewer_id
       foreign: viewed_id
       refClass: View

et View devrait ressembler

View:
  columns:
    viewed_id:
      type: integer
      primary: true
    viewer_id:
      type: integer
      primary: true

Voir la documentation Doctrine sur relations plusieurs-à-plusieurs .