Ich habe 3 Tabellen, die miteinander verbunden sind und ich versuche, die Daten korrekt abzufragen, so dass ich alles bekomme, was ich brauche.Komplexe MySQL Query Joining Tabellen korrekt
Hier sind die 3 Tabellen, die ich habe:
order_items
+------------+--------------+------+-----+
| order_id | product_id |count | max |
+------------+--------------+------+-----+
| 1AB45 | 3214 | 1 | 20 |
| YE72H | 314 | 2 | 20 |
| HWYE1 | 5311 | 3 | 10 |
| HWYE1 | 314 | 1 | 20 |
+------------+--------------+------+-----+
Aufträge
+-----------+-------------+---------+-----+
| order_id | buyer_email | user_id | ... |
+-----------+-------------+---------+-----+
| 1AB45 | [email protected] | 123 | |
| YE72H | [email protected] | 124 | |
| HWYE1 | [email protected] | 125 | |
+-----------+-------------+---------+-----+
reg_keys
+-----------+-------------+---------+------------+
| reg_key | time_redeem | user_id | product_id |
+-----------+-------------+---------+------------+
| UN-12XZ | 2015-11-12 | 123 | 3214 |
| UN-34AB | 2015-10-12 | 125 | 5311 |
| UN-67UY | 2015-09-12 | 125 | 314 |
+-----------+-------------+---------+------------+
ich alle von der Anmeldung Suche zu erhalten Schlüssel wo der count/quanity gleich 1 ist und time_redeemed nicht NULL ist. Hier ist meine Abfrage, die Ergebnisse bekommt aber überschreibt alle anderen, um Informationen mit der gleichen E-Mail/order_id:
SELECT * FROM order_items
JOIN orders ON orders.order_id = order_items.order_id
JOIN reg_keys ON reg_keys.user_id=orders.user_id and reg_keys.product_id=order_items.product_id
WHERE count=1 and reg_keys.redeemed_by is not null
GROUP BY reg_key ORDER BY time_redeem DESC
Dies zeitigt mir keine Ergebnisse. Was habe ich vermasselt?
'select *. . . Gruppe von "ist einfach falsch. Wenn Sie 'group by' verwenden, hätten Sie normalerweise Aggregationsfunktionen in' select'. –
Verwechslung von 'reg_keys.redeemed_by' in Abfrage und' reg_keys.time_redeem' in Ihrer Beschreibung? – Zimmi