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

Joindre plusieurs tables sans clé commune

Une approche possible :

SELECT l.Item, m.name, c.Color
      FROM linkage_Table AS l
INNER JOIN Material_Table AS m
        ON l.Material = '*'
           OR l.Material = m.name
INNER JOIN Color_Table AS c
        ON l.Color = '*'
           OR l.Color = c.Color

SQL Fiddle

Explication :la requête doit être construite de manière à ce que les tables 'matière' et 'couleur' ​​soient jointes complètement (jointure croisée), lorsque '*' est donné dans le champ correspondant, ou par égalité de ces champs. Et c'est exactement ce que nous avons obtenu en utilisant 'ON l.someField = '*' OR l.someField = joined.someField' clause.