Aşağıdakilerin neden çalışmadığını bana söyleyebilir mi? İki seçim arasında birleştirme anahtarı sözcüğü yakınında bir sözdizimi hatası şikayet ediyor.İki seçim deyimine katılma
SELECT *
FROM (select * from orders_products inner JOIN orders ON orders_products.orders_id = orders.orders_id where products_id = 181)
as A
join
SELECT *
FROM (select * from orders_products INNER JOIN orders ON orders_products.orders_id = orders.orders_id where products_id = 180)
as B
on A.orders_id=B.orders_id
Temelde benim ilk SELECT
bir tablodan bir ürüne yönelik tüm sipariş bilgileri çeker ve başka sipariş miktarını çeker ve bunları birbirine katılır. İkinci SELECT
, başka bir ürün için aynı şeyi yapar.
Şimdi, başka ben Belki burada bir yanlış yaklaşım alıyorum
Q_ID P_ID1 Q1 P_ID2 Q2
1 180 3 181 11
2 180 9 181 6
3 180 5 181 3
almak istiyorum katılmak kullanarak,
_______A_________ _______B_________
O_ID P_ID Q O_ID P_ID Q
1 180 3 1 181 11
2 180 9 2 181 6
3 180 5 3 181 3
içeriz. Baska öneri?
GÜNCELLEME: İşte RedFilter tarafından işaretçiler sonra benim için çalıştı budur:
(SELECT *
FROM (
SELECT * FROM orders_products
INNER JOIN orders ON orders_products.orders_id = orders.orders_id
WHERE products_id =181) AS A
LEFT JOIN (
SELECT * FROM orders_products
INNER JOIN orders ON orders_products.orders_id = orders.orders_id
WHERE products_id =180) AS B ON A.orders_id = B.orders_id
)
UNION (
SELECT *
FROM (
SELECT *
FROM orders_products
INNER JOIN orders ON orders_products.orders_id = orders.orders_id
WHERE products_id =181
) AS C
RIGHT JOIN (
SELECT *
FROM orders_products
INNER JOIN orders ON orders_products.orders_id = orders.orders_id
WHERE products_id =180
) AS D ON C.orders_id = D.orders_id
)
ummm tüm katılmadan gereksiz biraz .... görünüyor – Neal
Bunu sorgudan almak istiyorum ne tarif edebilir misiniz? Daha verimli bir yol olabilir. –