LEFT AND RIGHT OUTER JOINS problem
I am trying to display the total quantity sold and total sales for all of the sellers and the products even when they have not sold any of the products. I know that I have to use LEFT OUTER or RIGHT OUTER JOIN to join the tables together with NULL values.
SELECT se.seller_account_ref, se.seller_name, pro.product_code, pro.product_description, o.quantity AS [Total quantity sold], SUM(o.quantity)*o.price
FROM sellers se
INNER JOIN product_sellers pr ON se.seller_id = pr.seller_id
LEFT OUTER JOIN ordered_products o ON pr.seller_id = o.seller_id AND pr.product_id = o.product_id
LEFT OUTER JOIN products pro ON pr.product_id = pro.product_id
Even if I use left outer join I still have just 1 result for the query. Can You help me with what I am doing wrong, I think I don't understand the idea of the outer joins.
Thank You in advance guys
Can You help me with what I am doing wrong
Without the data to accompany your query, all anyone can reasonably do is speculate.
https://ibb.co/5cfYhvH kod do diagramu
kod do diagramu
All questions about why a given query does or does not work "really should" include sample data. A diagram of the schema is not nearly as helpful as the data. Posting a question about a query without sample data makes it far more difficult for this group's volunteers to help you, which greatly reduces the chances of getting a useful answer.
Can You let me know how I can give a sample of data ?
- Determine a minimum set of records from your dataset that, combined with your query, will show the problem you're describing.
- Pick out the
INSERTs from  that cover the records from .
- Post these
That way, anyone can paste all these commands directly into their own test DBs to verify your issue, and figure out what's going on.
Another way is to run
.mode insert, then run
SELECT statements to get a representative sample. Also, better run
.schema and post the needed bits (avoiding any tables and views not relevant to the question). Try your best to keep the size of the resulting post down to the bare minimum.
(3) By David Raymond (dvdraymond) on 2021-08-12 17:05:25 in reply to 1 [link] [source]
SELECT ..., SUM(o.quantity)*o.price
You've got an aggregate function in there, but no GROUP BY. So it's using all the rows as your group, and treating the rest of the columns are bare columns, which it's taking from one of the rows "at random" (not actually random, but that's another discussion)
You need to either group by something for which you want info on the groups... or get rid of the aggregate functions.