-
Notifications
You must be signed in to change notification settings - Fork 104
/
Copy pathSQL Exercises - JOINS on Sales Database.sql
419 lines (311 loc) · 14.1 KB
/
SQL Exercises - JOINS on Sales Database.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
/*** SQL Exercises - JOINS on Sales Database ***/
-- https://www.w3resource.com/sql-exercises/sql-joins-exercises.php
Table: salesman
salesman_id name city commission
----------- ---------- ---------- ----------
5001 James Hoog New York 0.15
5002 Nail Knite Paris 0.13
5005 Pit Alex London 0.11
5006 Mc Lyon Paris 0.14
5003 Lauson Hen 0.12
5007 Paul Adam Rome 0.13
Table: customer
customer_id cust_name city grade salesman_id
----------- ------------ ---------- ---------- -----------
3002 Nick Rimando New York 100 5001
3005 Graham Zusi California 200 5002
3001 Brad Guzan London 5005
3004 Fabian Johns Paris 300 5006
3007 Brad Davis New York 200 5001
3009 Geoff Camero Berlin 100 5003
3008 Julian Green London 300 5002
3003 Jozy Altidor Moscow 200 5007
Table: orders
ord_no purch_amt ord_date customer_id salesman_id
---------- ---------- ---------- ----------- -----------
70001 150.5 2012-10-05 3005 5002
70009 270.65 2012-09-10 3001 5005
70002 65.26 2012-10-05 3002 5001
70004 110.5 2012-08-17 3009 5003
70007 948.5 2012-09-10 3005 5002
70005 2400.6 2012-07-27 3007 5001
70008 5760 2012-09-10 3002 5001
70010 1983.43 2012-10-10 3004 5006
70003 2480.4 2012-10-10 3009 5003
70012 250.45 2012-06-27 3008 5002
70011 75.29 2012-08-17 3003 5007
70013 3045.6 2012-04-25 3002 5001
Table: company_mast
COM_ID COM_NAME
------ -------------
11 Samsung
12 iBall
13 Epsion
14 Zebronics
15 Asus
16 Frontech
Table: item_mast
PRO_ID PRO_NAME PRO_PRICE PRO_COM
------- ------------------------- ---------- ----------
101 Mother Board 3200 15
102 Key Board 450 16
103 ZIP drive 250 14
104 Speaker 550 16
105 Monitor 5000 11
106 DVD drive 900 12
107 CD drive 800 12
108 Printer 2600 13
109 Refill cartridge 350 13
110 Mouse 250 12
Table: emp_department
DPT_CODE DPT_NAME DPT_ALLOTMENT
-------- --------------- -------------
57 IT 65000
63 Finance 15000
47 HR 240000
27 RD 55000
89 QC 75000
Table: emp_details
EMP_IDNO EMP_FNAME EMP_LNAME EMP_DEPT
--------- --------------- --------------- ----------
127323 Michale Robbin 57
526689 Carlos Snares 63
843795 Enric Dosio 57
328717 Jhon Snares 63
444527 Joseph Dosni 47
659831 Zanifer Emily 47
847674 Kuleswar Sitaraman 57
748681 Henrey Gabriel 47
555935 Alex Manuel 57
539569 George Mardy 27
733843 Mario Saule 63
631548 Alan Snappy 27
839139 Maria Foster 57
/* 1. Write a SQL statement to prepare a list with salesman name, customer name and their cities for the salesmen and customer who belongs to the same city. */
SELECT s.name,
c.cust_name,
c.city
FROM salesman s
INNER JOIN customer c
ON s.city = c.city;
/* 2. Write a SQL statement to make a list with order no, purchase amount, customer name and their cities for those orders which order amount between 500 and 2000 */
SELECT o.ord_no,
o.purch_amt,
c.cust_name,
c.city
FROM orders o
INNER JOIN customer c
ON o.customer_id = c.customer_id
WHERE o.purch_amt BETWEEN 500 AND 2000;
/* 3. Write a SQL statement to know which salesman are working for which customer. */
SELECT c.cust_name AS "Customer Name",
s.name AS "Salesman"
FROM customer c
INNER JOIN salesman s
ON c.salesman_id = s.salesman_id;
/* 4. Write a SQL statement to find the list of customers who appointed a salesman for their jobs who gets a commission from the company is more than 12%. */
SELECT c.cust_name AS "Customer Name",
c.city,
s.name AS "Salesman",
s.commission
FROM customer c
INNER JOIN salesman s
ON c.salesman_id = s.salesman_id
WHERE s.commission > 0.12;
/* 5. Write a SQL statement to find the list of customers who appointed a salesman for their jobs who does not live in the same city where their customer lives, and gets a commission is above 12% . */
SELECT c.cust_name AS "Customer Name",
c.city AS "Customer City",
s.name AS "Salesman",
s.city AS "Salesman City",
s.commission
FROM customer c
INNER JOIN salesman s
ON c.salesman_id = s.salesman_id
WHERE s.commission > 0.12
AND c.city != s.city;
/* 6. Write a SQL statement to find the details of an order i.e. order number, order date, amount of order, which customer gives the order and which salesman works for that customer and how much commission he gets for an order. */
SELECT o.ord_no,
o.ord_date,
o.purch_amt,
c.cust_name AS "Customer Name",
s.name AS "Salesman",
s.commission
FROM orders o
INNER JOIN customer c
ON o.customer_id=c.customer_id
INNER JOIN salesman s
ON o.salesman_id=s.salesman_id;
/* 7. Write a SQL statement to make a join on the tables salesman, customer and orders in such a form that the same column of each table will appear once and only the relational rows will come.
SELECT *
FROM orders
NATURAL JOIN customer
NATURAL JOIN salesman;
/* 8. Write a SQL statement to make a list in ascending order for the customer who works either through a salesman or by own. */
SELECT c.cust_name AS "Customer Name"
FROM customer c
LEFT JOIN salesman s
ON c.salesman_id=s.salesman_id
ORDER BY c.customer_id ASC;
/* 9. Write a SQL statement to make a list in ascending order for the customer who holds a grade less than 300 and works either through a salesman or by own. */
SELECT c.cust_name AS "Customer Name",
c.grade
FROM customer c
LEFT JOIN salesman s
ON c.salesman_id=s.salesman_id
WHERE c.grade < 300
ORDER BY c.customer_id ASC;
/* 10. Write a SQL statement to make a report with customer name, city, order number, order date, and order amount in ascending order according to the order date to find that either any of the existing customers have placed no order or placed one or more orders. */
SELECT c.cust_name AS "Customer Name",
c.city,
o.ord_no,
o.ord_date,
o.purch_amt
FROM customer c
LEFT OUTER JOIN orders o
ON c.customer_id=o.customer_id
ORDER BY o.ord_date;
/* 11. Write a SQL statement to make a report with customer name, city, order number, order date, order amount, salesman name and commission to find that either any of the existing customers have placed no order or placed one or more orders by their salesman or by own. */
SELECT c.cust_name AS "Customer Name",
c.city,
o.ord_no,
o.ord_date,
o.purch_amt,
s.name AS "Salesman",
s.commission
FROM customer c
LEFT OUTER JOIN orders o
ON c.customer_id=o.customer_id
LEFT OUTER JOIN salesman s
ON c.salesman_id=s.salesman_id;
/* 12. Write a SQL statement to make a list in ascending order for the salesmen who works either for one or more customer or not yet join under any of the customers. */
SELECT s.name AS "Salesman"
FROM salesman s
LEFT OUTER JOIN customer c
ON s.salesman_id=c.salesman_id
ORDER BY c.salesman_id ASC;
/* 13. Write a SQL statement to make a list for the salesmen who works either for one or more customer or not yet join under any of the customers who placed either one or more orders or no order to their supplier. */
SELECT s.name AS "Salesman"
FROM salesman s
LEFT OUTER JOIN customer c
ON s.salesman_id=c.salesman_id
LEFT OUTER JOIN orders o
ON c.customer_id=o.customer_id;
/* 14. Write a SQL statement to make a list for the salesmen who either work for one or more customers or yet to join any of the customer. The customer may have placed, either one or more orders on or above order amount 2000 and must have a grade, or he may not have placed any order to the associated supplier. /*
SELECT s.name AS "Salesman"
FROM salesman s
LEFT OUTER JOIN customer c
ON s.salesman_id=c.salesman_id
LEFT OUTER JOIN orders o
ON c.customer_id=o.customer_id
WHERE o.purch_amt >= 2000
AND grade IS NOT NULL;
/* 15. Write a SQL statement to make a report with customer name, city, order no, order date, purchase amount for those customers from the existing list who placed one or more orders or which order(s) have been placed by the customer who is not on the list. */
SELECT c.cust_name AS "Customer Name",
c.city,
o.ord_no,
o.ord_date,
o.purch_amt
FROM customer c
RIGHT JOIN orders o
ON c.customer_id= o.customer_id;
/* 16. Write a SQL statement to make a report with customer name, city, order no. order date, purchase amount for only those customers on the list who must have a grade and placed one or more orders or which order(s) have been placed by the customer who is neither in the list nor have a grade. */
SELECT c.cust_name AS "Customer Name",
c.city,
o.ord_no,
o.ord_date,
o.purch_amt
FROM customer c
FULL OUTER JOIN orders o
ON c.customer_id= o.customer_id
AND c.grade IS NOT NULL;
/* 17. Write a SQL statement to make a cartesian product between salesman and customer i.e. each salesman will appear for all customer and vice versa. */
SELECT s.name AS "Salesman",
c.cust_name AS "Customer Name"
FROM salesman s
CROSS JOIN customer c;
/* 18. Write a SQL statement to make a cartesian product between salesman and customer i.e. each salesman will appear for all customer and vice versa for that customer who belongs to a city. */
SELECT s.name AS "Salesman",
c.cust_name AS "Customer Name"
FROM salesman s
CROSS JOIN customer c
WHERE s.city IS NOT NULL;
/* 19. Write a SQL statement to make a cartesian product between salesman and customer i.e. each salesman will appear for all customer and vice versa for those salesmen who belongs to a city and the customers who must have a grade. */
SELECT s.name AS "Salesman",
c.cust_name AS "Customer Name"
FROM salesman s
CROSS JOIN customer c
WHERE s.city IS NOT NULL
AND c.grade IS NOT NULL;
/* 20. Write a SQL statement to make a cartesian product between salesman and customer i.e. each salesman will appear for all customer and vice versa for those salesmen who must belong a city which is not the same as his customer and the customers should have an own grade. */
SELECT s.name AS "Salesman",
c.cust_name AS "Customer Name"
FROM salesman s
CROSS JOIN customer c
WHERE s.city IS NOT NULL
AND s.city != c.city
AND c.grade IS NOT NULL;
/* 21. Write a SQL query to display all the data from the item_mast, including all the data for each item's producer company. */
SELECT *
FROM item_mast i
INNER JOIN company_mast c
ON i.pro_com=c.com_id;
/* 22. Write a SQL query to display the item name, price, and company name of all the products. */
SELECT i.pro_name,
i.pro_price,
c.com_name
FROM item_mast i
INNER JOIN company_mast c
ON i.pro_com=c.com_id;
/* 23. Write a SQL query to display the average price of items of each company, showing the name of the company. */
SELECT c.com_name,
AVG(i.pro_price)
FROM item_mast i
INNER JOIN company_mast c
ON i.pro_com=c.com_id
GROUP BY c.com_name;
/* 24. Write a SQL query to display the names of the company whose products have an average price larger than or equal to Rs. 350. */
SELECT c.com_name,
AVG(i.pro_price)
FROM item_mast i
INNER JOIN company_mast c
ON i.pro_com=c.com_id
GROUP BY c.com_name
HAVING AVG(i.pro_price) >= 350;
/* 25. Write a SQL query to display the name of each company along with the ID and price for their most expensive product. */
SELECT c.com_name,
i.pro_name,
i.pro_price
FROM item_mast i
INNER JOIN company_mast c
ON i.pro_com=c.com_id
AND i.pro_price = (SELECT MAX(i.pro_price)
FROM item_mast i
WHERE i.pro_com = c.com_id);
/* 26. Write a query in SQL to display all the data of employees including their department. */
SELECT *
FROM emp_details edet
INNER JOIN emp_department edep
ON edet.emp_dept = edep.dpt_code;
/* 27. Write a query in SQL to display the first name and last name of each employee, along with the name and sanction amount for their department. */
SELECT edet.emp_fname AS "First Name",
edet.emp_lname AS "Last Name",
edep.dpt_name AS "Department Name",
edep.dpt_allotment AS "Amount Allotted"
FROM emp_details edet
INNER JOIN emp_department edep
ON edet.emp_dept = edep.dpt_code;
/* 28. Write a query in SQL to find the first name and last name of employees working for departments with a budget more than Rs. 50000. */
SELECT edet.emp_fname AS "First Name",
edet.emp_lname AS "Last Name"
FROM emp_details edet
INNER JOIN emp_department edep
ON edet.emp_dept = edep.dpt_code
AND edep.dpt_allotment > 50000;
/* 29. Write a query in SQL to find the names of departments where more than two employees are working. */
SELECT edep.dpt_name,
COUNT(edet.emp_idno)
FROM emp_details edet
INNER JOIN emp_department edep
ON edet.emp_dept = edep.dpt_code
GROUP BY edep.dpt_name
HAVING COUNT(edet.emp_idno) > 2;