TSQL Exercise on Adventure Works Database part-1

Hi Folks,

I am writing a series of posts on AdventureWorksLT database which can be downloaded from the link AdventureworksLT2012. I downloaded 2012 version from it.

The main theme of this is to help the beginners to enhance their T-SQL capabilities on a phase by phase manner.  This will be in Q & A format.

Note: These are available on the internet but not available at single place hence I made an effort to bring them all together.

1. Retrieve customer details Familiarize yourself with the Customer table by writing a Transact-SQL query that retrieves all columns for all customers.

SELECT * FROM SalesLT.Customer;

2. Retrieve customer name data Create a list of all customer contact names that includes the title, first name, middle name (if any), last name, and suffix (if any) of all customers.

SELECT Title, FirstName, MiddleName, LastName, Suffix FROM SalesLT.Customer;

3. Retrieve customer names and phone numbers Each customer has an assigned salesperson. You must write a query to create a call sheet that lists:

(i)The salesperson
(ii)A column named CustomerName that displays how the customer contact should be greeted (for example, “Mr Smith”)
(iii)The customer’s phone number.

SELECT Salesperson, Title + ' ' + LastName AS CustomerName, Phone FROM SalesLT.Customer;

4.Retrieve a list of customer companies

You have been asked to provide a list of all customer companies in the format
<Customer ID> : <Company Name> - for example, 78: Preferred Bikes.

SELECT CAST(CustomerID AS varchar) + ': ' + CompanyName AS CustomerCompany FROM SalesLT.Customer;

5.Retrieve a list of sales order revisions The SalesLT.SalesOrderHeader table contains records of sales orders. You have been asked to retrieve data for a report that shows:

The sales order number and revision number in the format <Order Number> (<Revision>) – for example SO71774 (2).
The order date converted to ANSI standard format (yyyy.mm.dd – for example 2015.01.31).

SELECT SalesOrderNumber + ' (' + STR(RevisionNumber, 1) + ')' AS OrderRevision, CONVERT(nvarchar(30), OrderDate, 102) AS OrderDate
FROM SalesLT.SalesOrderHeader;

6. Retrieve customer contact names with middle names if known You have been asked to write a query that returns a list of customer names.
The list must consist of a single field in the format <first name> <last name> (for example Keith Harris) if the middle name is unknown, or <first name> <middle name> <last name> (for example Jane M. Gates) if a middle name is stored in the database.

SELECT FirstName + ' ' + ISNULL(MiddleName + ' ', '')+ LastName AS CustomerNameFROM SalesLT.Customer;

7.Retrieve primary contact details

Customers may provide adventure Works with an email address, a phone number, or both. If an email address is available, then it should be used as the primary contact method; if not, then the phone number should be used. You must write a query that returns a list of customer IDs in one column, and a second column named PrimaryContact that contains the email address if known, and otherwise the phone number.

IMPORTANT: In the sample data provided in AdventureWorksLT, there are no customer records without an email address. Therefore, to verify that your query works as expected, run the following UPDATE statement to remove some existing email addresses before creating your query

UPDATE SalesLT.Customer SET EmailAddress = NULL WHERE CustomerID % 7 = 1;

SELECT CustomerID,
case
when EmailAddress is not null then emailaddress
else phone
end as 'primary contact' FROM SalesLT.Customer;

SELECT CustomerID, COALESCE(EmailAddress, Phone) AS PrimaryContact FROM SalesLT.Customer;

8.You have been asked to create a query that returns a list of sales order IDs and order dates with a column named ShippingStatus that contains the text “Shipped” for orders with a known ship date, and “Awaiting Shipment” for orders with no ship date.

IMPORTANT: In the sample data provided in AdventureWorksLT, there are no sales order header records without a ship date. Therefore, to verify that your query works as expected, run the following UPDATE statement to remove some existing ship dates before creating your query

UPDATE SalesLT.SalesOrderHeader SET ShipDate = NULL WHERE SalesOrderID > 71899;

SELECT SalesOrderID, OrderDate,
    CASE
      WHEN ShipDate IS NULL THEN 'Awaiting Shipment'
      ELSE 'Shipped'
    END AS ShippingStatus
FROM SalesLT.SalesOrderHeader;

Comments

Unknown said…
can you please post exercises for 2019 databases aswell please. these are very useful
Kote Easwar said…
Very nice vamsy....it's very helpful....