SQL Exercises: Orders smaller than any amount for a London customer
24. From the following tables write a SQL query to find orders where the order amount is less than the order amount of a customer residing in London City. Return ord_no, purch_amt, ord_date, customer_id and salesman_id.
Sample table: Ordersord_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 5001Sample 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 100 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 Moncow 200 5007
Sample Solution:
-- Selecting all columns from the 'orders' table
SELECT *
-- Specifying the table to retrieve data from ('orders')
FROM orders
-- Filtering the results based on the condition that 'purch_amt' is less than any value in the set of 'purch_amt' returned by a correlated subquery
WHERE purch_amt < ANY
-- Correlated Subquery: Selecting 'purch_amt' values from the 'orders' table (aliased as 'a') where 'customer_id' matches the outer query's 'customer_id' and 'city' is 'London' in the 'customer' table (aliased as 'b')
(SELECT purch_amt
FROM orders a, customer b
WHERE a.customer_id = b.customer_id
AND b.city = 'London');
Sample Output:
ord_no purch_amt ord_date customer_id salesman_id 70002 65.26 2012-10-05 3002 5001 70004 110.50 2012-08-17 3009 5003 70011 75.29 2012-08-17 3003 5007 70001 150.50 2012-10-05 3005 5002 70012 250.45 2012-06-27 3008 5002
Explanation:
The above SQL query is selecting all columns (*) from the 'orders' table where the "purch_amt" value of the row is less than any of the "purch_amt" values in the subquery.
The subquery is joining the 'orders' table (alias as 'a') with the 'customer' table (alias as 'b') on the "customer_id" column and then selecting the "purch_amt" column from the 'orders' table for the rows where the "city" value of the 'customer' table is 'London'.
The ANY keyword is used to check if there is any value in the subquery that the outer query's condition is true for. In this case, the outer query will only return the rows from the 'orders' table whose purch_amt is less than any of the purch_amt of orders placed by the customer from London.
Visual Explanation:
Note : For some necessery regions data might have changed. You can get different result.
Practice Online
Sample Database: inventory
Query Visualization:
Duration:
Rows:
Cost:
Contribute your code and comments through Disqus.
Previous SQL Exercise: All orders with amounts greater than one on given date.
Next SQL Exercise: Orders higher than any amount for a London customer.
What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics