Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Wählen Sie Produkte nach mehreren Attributen aus und verwenden Sie AND statt OR Concatenator, Datenmodell EAV

Ihre Unterabfrage sollte folgendermaßen aussehen:

SELECT
  attributes_entity.product_id
FROM
  attributes_entity INNER JOIN attributes
  ON attributes_entity.attribute_id=attributes.id
  INNER JOIN attributes_values ON
  attributes_entity.value_id=attributes_values.id 
WHERE 
  (attributes.name="Memory" AND attributes_values.value="16GB") 
  OR
  (attributes.name="Color" AND attributes_values.value="Gold")
GROUP BY
  attributes_entity.product_id
HAVING
  COUNT(DISTINCT attributes.name)=2

Diese Lösung verwendet eine GROUP BY-Unterabfrage. Sie müssen OR verwenden, da das Attribut nicht gleichzeitig Speicher und Farbe in derselben Zeile sein kann, sie können beide wahr sein, aber in verschiedenen Zeilen. COUNT(DISTINCT attributes.name) zählt die Anzahl Attribute, die entweder Farbe oder Speicher sind, wenn es 2 ist, dann gibt es mindestens 1 Zeile, wo die erste Bedingung wahr ist, und 1 Zeile, wo die andere auch wahr ist.