sql >> Database >  >> RDS >> Mysql

Aantal gefacetteerde zoekkenmerken

Hier is hoe je dit kunt doen:

SELECT meta_name, meta_value, COUNT(DISTINCT item_id) count
  FROM meta m JOIN item_meta im
    ON im.field_id = m.id
 GROUP BY meta_name, meta_value

Uitgang:

|      META_NAME | META_VALUE | COUNT |
|----------------|------------|-------|
|       Car Type |      Coupe |     2 |
|       Car Type |      Sedan |     1 |
|          Color |      Black |     1 |
|          Color |        Red |     1 |
|          Color |      White |     1 |
| Interior Color |      Black |     2 |
| Interior Color |       Grey |     1 |
|           Make |        BMW |     2 |
|           Make |      Honda |     1 |
|          Model |    2Series |     1 |
|          Model |    3Series |     1 |
|          Model |      Civic |     1 |

Hier is SQLFiddle demo

UPDATE:

Gefilterd:

SELECT meta_name, meta_value, COUNT(DISTINCT item_id) count
  FROM meta m JOIN item_meta im
    ON im.field_id = m.id
 WHERE item_id IN
(
  SELECT i.id
  FROM item_meta im JOIN items i
    ON im.item_id = i.id JOIN meta m
    ON im.field_id = m.id
 GROUP BY i.id
HAVING MAX(meta_name = 'Make' AND meta_value = 'BMW') = 1
   AND MAX(meta_name = 'Car Type' AND meta_value = 'Coupe') = 1
)
 GROUP BY meta_name, meta_value;

Uitgang:

|      META_NAME | META_VALUE | COUNT |
|----------------|------------|-------|
|       Car Type |      Coupe |     2 |
|          Color |      Black |     1 |
|          Color |      White |     1 |
| Interior Color |      Black |     1 |
| Interior Color |       Grey |     1 |
|           Make |        BMW |     2 |
|          Model |    2Series |     1 |
|          Model |    3Series |     1 |

Hier is SQLFiddle demo

UPDATE2:

Het is gemakkelijk. Natuurlijk in plaats van AND in HAVING clausule (een auto kan niet tegelijkertijd zwart en rood zijn) moet je OR . gebruiken leuk vinden

HAVING MAX(meta_name = 'Color' AND meta_value = 'Black') = 1
    OR MAX(meta_name = 'Color' AND meta_value = 'Red')   = 1

of hier is een andere manier om dezelfde intentie uit te drukken

HAVING MAX(meta_name = 'Color' AND meta_value = 'Black') +
       MAX(meta_name = 'Color' AND meta_value = 'Red') > 0

Hier is SQLFiddle demo



  1. Tabel automatisch vernieuwen zonder pagina te vernieuwen PHP MySQL

  2. Geef WAAR parameters door aan PostgreSQL View?

  3. MySQL - mysqldump --routines om slechts 1 opgeslagen procedure (op naam) te exporteren en niet elke routine

  4. PHP MySQL Yii - database lezen niet schrijven