Mysql
 sql >> Database >  >> RDS >> Mysql

MySQL:due chiavi esterne in una tabella che fanno riferimento a un'altra tabella

Ed eccoci qua:hai specificato gli stessi alias per le relazioni.

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

Oppure imposti l'intera relazione molti-a-molti in modo diverso:

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

e View dovrebbe assomigliare a

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

Consulta la documentazione di Doctrine su relazioni molti-a-molti .