Find Region name which has most customers.
Ans: select region from (select count(customerid) "count1",region from customers where region is not null
group by region order by "count1" desc) where rownum=1;
Find the best sales month in northwind?
Ans: select "BestMonth" from (select count(orderid) "totalvalue",to_char(orderdate,'month') "BestMonth"
from orders group by to_char(orderdate,'month')order by "totalvalue" desc) where rownum=1;
Create customer report(customer-id - customer name-address-total order value)
Ans: select c.customerid,c.companyname,c.address,sum( orderdetails.unitprice * quantity) as totalvalue from customers c join orders on c.customerid=orders.customerid
join orderdetails on orders.orderid=orderdetails.orderid
group by c.customerid,c.companyname,c.address
Employees list with(total order values) from high to low.
Ans: select e.firstname,sum(quantity* unitprice) "total" from employees e,orders,orderdetails
where orders.employeeid=e.employeeid and orderdetails.orderid =orders.orderid group by firstname order by "total" desc
Oralce queries,Northwind database solutions,sql queries,pl sql,pl/sql,oracle sql,oracle pl/sql,oracle sql tutorial with examples,oracle pl/sql tutorial with examples,sql tutorial,sql tutorial with examples,pl/sql tutorial with examples
Monday, July 5, 2010
Northwind Database Exercise
The Northwind database is a sample database used by Microsoft to demonstrate the features of some of its products, including SQL Server and Microsoft Access. The database contains the sales data for Northwind Traders, a fictitious specialty foods export-import company.
Although the code taught in this class is not specific to Microsoft products, we use the Northwind database for many of our examples because many people are already familiar with it and because there are many resources for related learning that make use of the same database.
The diagram below shows the table structure of the Northwind database.
The Northwind database has additional tables, but we will only be using the ones shown above. In this lesson, we will explore some of these tables
Northwind Database Exercise Soluations
Create a report that shows the product name and supplier id for all products supplied by Exotic Liquids, Grandma Kelly's Homestead, and Tokyo Traders.
Ans: select s.supplierid,s.companyname,p.productid,p.productname from suppliers s join products p on(s.supplierid= p.supplierid) and s.companyname IN('Grandma Kelly''s Homestead','Tokyo Traders','Exotic Liquids')
Create a report that shows all products by name that are in the Seafood category.
Ans: select p.productid,p.productname,c.categoryid,c.categoryname from products p join categories c on (p.categoryid=c.categoryid)and c.categoryname like '%Seafood%'
Create a report that shows all companies by name that sell products in CategoryID8.
Ans: select count(companyname),p.categoryid,s.companyname from products p join suppliers s on (p.supplierid = s.supplierid) and categoryid=8 group by s.companyname,p.categoryid
Create a report that shows all companies by name that sell products in the Seafood category.
Ans: select s.companyname from suppliers s where supplierid IN(select p.supplierid from products p join categories c on (c.categoryid=p.categoryid)and c.categoryname= 'Seafood')
Create a report showing the Order ID, the name of the company that placed the order,
and the first and last name of the associated employee.
Only show orders placed after January 1, 1998 that shipped after they were required.
Sort by Company Name.
Ans: select o.orderid,c.customerid,c.companyname from orders o join customers c on (c.customerid=o.customerid)
where o.orderdate > '1-jan-1998' and o.shippeddate >'1-jan-1998' and o.requireddate >'1-jan-1998'
Which products are provided by which suppliers.
Ans: select p.productname,s.companyname from products p join suppliers s on (p.supplierid=s.supplierid)
Create a report that shows the order ids and the associated employee names for orders that shipped after the required date.
Ans: select e.employeeid,e.firstname,o.orderid from employees e join orders o on(o.employeeid=e.employeeid)where requireddate
Create a report that shows the total quantity of products (from the Order_Details table) ordered. Only show records for products for which the quantity ordered is fewer than 200.
Ans: select p.productname,sum(o.quantity) from products p join orderdetails o on(p.productid=o.productid) group by p.productname having sum(o.quantity)
Create a report that shows the total number of orders by Customer since December 31, 1996. The report should only return rows for which the NumOrders is greater than 15. The report should return the following 5 rows.
Ans: select c.companyname,count(o.orderid) from orders o join customers c on(o.customerid= c.customerid) where o.orderdate >= '31-dec-1996'
group by c.companyname having count(o.orderid)>15 order by count(o.orderid)
Create a report that shows the company name, order id, and total price of all products of which Northwind has sold more than $10,000 worth. There is no need for a GROUP BY clause in this report.
Ans: select c.companyname,o.orderid,(((unitprice)-(unitprice*discount))*(quantity))As total from customers c join orders o on(o.customerid=c.customerid) join orderdetails_1 ord on(ord.orderid=o.orderid)
where(((unitprice)-(unitprice*discount))*(quantity)) > 10000
Create a report that shows the number of employees and customers from each city that
has employees in it.
Ans: select count(distinct(e.employeeid))as Numemp,count(distinct(c.customerid)) as Numcus,e.city,c.city from employees e join customers c on(e.city=c.city)
group by e.city,c.city order by Numemp
Create a report that shows the company names and faxes for all customers. If the customer doesn't have a fax, the report should show "No Fax" in that field
Ans: select customerid,companyname,
( CASE
when fax= ' ' Then 'No Fax'
End )fax
from customers
Subscribe to:
Posts (Atom)