Northwind - Queries

Queries - is a subset of one or more tables used to restrict access to certin columns or rows of data within a table


Alphabetical List of Products 
Category Sales for 1997 
Current Product List 
Customer and Suppliers by City 
Employee Sales by Country 
Invoices 
Invoices Filter 
Order Details Extended 
Order Subtotals 
Order Qry 
Product Sales for 1997 
Products Above Average Price 
Products by Category 
Quarterly Orders 
Quarterly Orders By Product 
Sales by Category 
Sales by Year 
Sales Totals by Amount 
Summary of Sale by Quarter 
Summary of Sales by Year 
Ten Most Expensive Products 

Alphabetical List of Products

Access

SELECT         Products.* 
                     ,Categories.CategoryName
FROM Categories
INNER JOIN Products
ON Categories.CategoryID = Products.CategoryID
WHERE Products.Discontinued = No

SQL Server

SELECT         dbo.Products.ProductID 
                     ,dbo.Products.ProductName
                     ,dbo.Products.SupplierID
                     ,dbo.Products.CategoryID
                     ,dbo.Products.QuantityPerUnit
                     ,dbo.Products.UnitPrice
                     ,dbo.Products.UnitsInStock
                     ,dbo.Products.UnitsOnOrder
                     ,dbo.Products.ReorderLevel
                     ,dbo.Products.Discontinued
                     ,dbo.Categories.CategoryName
FROM dbo.Categories
INNER JOIN dbo.Products
ON dbo.Categories.CategoryID = dbo.Products.CategoryID
WHERE dbo.Products.Discontinued = 0

Category Sales for 1997

Access

SELECT DISTINCTROW  [Product Sales for 1997].CategoryName 
      ,SUM([Product Sales for 1997].ProductSales) AS CategorySales
FROM [Product Sales for 1997]
GROUP BY [Product Sales for 1997].CategoryName

SQL Server

SELECT     CategoryName 
      ,SUM(ProductSales) AS CategorySales
FROM dbo.[Product Sales for 1997]
GROUP BY CategoryName

Current Product List

Access

SELECT     [Product List].ProductID 
      ,[Product List].ProductName
FROM Products AS [Product List]
WHERE [Product List].Discontinued = No
ORDER BY [Product List].ProductName

SQL Server

SELECT     ProductID 
      ,ProductName
FROM dbo.Products AS Product_List
WHERE (Discontinued = 0)

Customer and Suppliers by City

Access

SELECT     City 
      ,CompanyName
      ,ContactName
      ,"Customers" AS [Relationship]
FROM Customers
UNION SELECT City
      ,CompanyName
      ,ContactName
      ,"Suppliers"
FROM Suppliers
ORDER BY City,
      CompanyName;

SQL Server

SELECT     City 
      ,CompanyName
      ,ContactName
      ,'Customers' AS Relationship
FROM dbo.Customers
UNION
SELECT City
      ,CompanyName
      ,ContactName
',Suppliers' AS Expr1
FROM dbo.Suppliers

Employee Sales by Country

Access

PARAMETERS    [Beginning Date] DateTime, [Ending Date] DateTime 
SELECT DISTINCTROW Employees.Country
      ,Employees.LastName
      ,Employees.FirstName
      ,Orders.ShippedDate
      ,Orders.OrderID
      ,[Order Subtotals].Subtotal AS SaleAmount
FROM Employees
INNER JOIN (Orders
INNER JOIN [Order Subtotals]
ON Orders.OrderID = [Order Subtotals].OrderID)
ON Employees.EmployeeID = Orders.EmployeeID
WHERE (Orders.ShippedDate) BETWEEN [Beginning Date] AND [Ending Date])

SQL Server

not provided in SQL Server


Invoices

Access

CCur is not available in SQL Server

SELECT     Orders.ShipName 
      ,Orders.ShipAddress
      ,Orders.ShipCity
      ,Orders.ShipRegion
      ,Orders.ShipPostalCode
      ,Orders.ShipCountry
      ,Orders.CustomerID
      ,Customers.CompanyName
      ,Customers.Address
      ,Customers.City
      ,Customers.Region
      ,Customers.PostalCode
      ,Customers.Country
      ,[FirstName] & " " & [LastName] AS Salesperson
      ,Orders.OrderID
      ,Orders.OrderDate
      ,Orders.RequiredDate
      ,Orders.ShippedDate
      ,Shippers.CompanyName
      ,[Order Details].ProductID
      ,Products.ProductName
      ,[Order Details].UnitPrice
      ,[Order Details].Quantity
      ,[Order Details].Discount
      ,CCur([Order Details].UnitPrice * [Quantity] * (1 - [Discount]) / 100) * 100 AS ExtendedPrice
      ,Orders.Freight
FROM SHIPPERS
INNER JOIN (PRODUCTS
 INNER JOIN (
        (EMPLOYEES
  INNER JOIN (CUSTOMERS
   INNER JOIN ORDERS
   ON Customers.CustomerID = Orders.CustomerID)
  ON Employees.EmployeeID = Orders.EmployeeID)
  INNER JOIN [Order Details]
  ON Orders.OrderID = [Order Details].OrderID)
 ON Products.ProductID = [Order Details].ProductID
)
ON Shippers.ShipperID = Orders.ShipVia

SQL Server

SELECT     dbo.Orders.ShipName 
      ,dbo.Orders.ShipAddress
      ,dbo.Orders.ShipCity
      ,dbo.Orders.ShipRegion
      ,dbo.Orders.ShipPostalCode
      ,dbo.Orders.ShipCountry
      ,dbo.Orders.CustomerID
      ,dbo.Customers.CompanyName AS CustomerName
      ,dbo.Customers.Address
      ,dbo.Customers.City
      ,dbo.Customers.Region
      ,dbo.Customers.PostalCode
      ,dbo.Customers.Country
      ,dbo.Employees.FirstName + ' ' + dbo.Employees.LastName AS Salesperson
      ,dbo.Orders.OrderID
      ,dbo.Orders.OrderDate
      ,dbo.Orders.RequiredDate
      ,dbo.Orders.ShippedDate
      ,dbo.Shippers.CompanyName AS ShipperName
      ,dbo.[Order Details].ProductID
      ,dbo.Products.ProductName
      ,dbo.[Order Details].UnitPrice
      ,dbo.[Order Details].Quantity
      ,dbo.[Order Details].Discount
      ,CONVERT(money, (dbo.[Order Details].UnitPrice * dbo.[Order Details].Quantity) * (1 - dbo.[Order Details].Discount) / 100) * 100 AS ExtendedPrice
      ,dbo.Orders.Freight
FROM dbo.SHIPPERS
INNER JOIN dbo.PRODUCTS
INNER JOIN dbo.EMPLOYEES
INNER JOIN dbo.CUSTOMERS
INNER JOIN dbo.ORDERS
ON dbo.Customers.CustomerID = dbo.Orders.CustomerID
ON dbo.Employees.EmployeeID = dbo.Orders.EmployeeID
INNER JOIN dbo.[Order Details]
ON dbo.Orders.OrderID = dbo.[Order Details].OrderID
ON dbo.Products.ProductID = dbo.[Order Details].ProductID
ON dbo.Shippers.ShipperID = dbo.Orders.ShipVia

Invoices Filter

Access

SELECT     Invoices.* 
FROM INVOICES
WHERE (Invoices.OrderID)=[Forms]![Orders]![OrderID])

SQL Server

not provided in SQL Server


Order Details Extended

Access

CCur is not available in SQL Server

SELECT     [Order Details].OrderID 
      ,[Order Details].ProductID
      ,Products.ProductName
      ,[Order Details].UnitPrice
      ,[Order Details].Quantity
      ,[Order Details].Discount
      ,CCur([Order Details].UnitPrice * [Quantity] * (1 - [Discount]) / 100) * 100 AS ExtendedPrice
FROM Products
INNER JOIN [Order Details]
ON Products.ProductID = [Order Details].ProductID
ORDER BY [Order Details].OrderID

SQL Server

SELECT     dbo.[Order Details].OrderID D 
      ,dbo.[Order Details].ProductID
      ,dbo.Products.ProductName
      ,dbo.[Order Details].UnitPrice
      ,dbo.[Order Details].Quantity
      ,dbo.[Order Details].Discount
      ,CONVERT(money, (dbo.[Order Details].UnitPrice * dbo.[Order Details].Quantity) * (1 - dbo.[Order Details].Discount) / 100) * 100 AS ExtendedPrice
FROM dbo.Products
INNER JOIN dbo.[Order Details]
ON dbo.Products.ProductID = dbo.[Order Details].ProductID

Order Subtotals

Access

SELECT     [Order Details].OrderID, 
      SUM(CCur([UnitPrice] * [Quantity] * (1 - [Discount]) / 100) * 100) AS Subtotal
FROM [Order Details]
GROUP BY [Order Details].OrderID;

SQL Server

SELECT     OrderID, 
      SUM(CONVERT(money, (UnitPrice * Quantity) * (1 - Discount) / 100) * 100) AS Subtotal
FROM dbo.[Order Details]
GROUP BY OrderID

Order Qry

Access

SELECT     Orders.OrderID 
      ,Orders.CustomerID
      ,Orders.EmployeeID
      ,Orders.OrderDate
      ,Orders.RequiredDate
      ,Orders.ShippedDate
      ,Orders.ShipVia
      ,Orders.Freight
      ,Orders.ShipName
      ,Orders.ShipAddress
      ,Orders.ShipCity
      ,Orders.ShipRegion
      ,Orders.ShipPostalCode
      ,Orders.ShipCountry
      ,Customers.CompanyName
      ,Customers.Address
      ,Customers.City
      ,Customers.Region
      ,Customers.PostalCode
      ,Customers.Country
FROM CUSTOMERS
INNER JOIN ORDERS
ON Customers.CustomerID = Orders.CustomerID;

SQL Server

SELECT     dbo.Orders.OrderID 
      ,dbo.Orders.CustomerID
      ,dbo.Orders.EmployeeID
      ,dbo.Orders.OrderDate
      ,dbo.Orders.RequiredDate
      ,dbo.Orders.ShippedDate
      ,dbo.Orders.ShipVia
      ,dbo.Orders.Freight
      ,dbo.Orders.ShipName
      ,dbo.Orders.ShipAddress
      ,dbo.Orders.ShipCity
      ,dbo.Orders.ShipRegion
      ,dbo.Orders.ShipPostalCode
      ,dbo.Orders.ShipCountry
      ,dbo.Customers.CompanyName
      ,dbo.Customers.Address
      ,dbo.Customers.City
      ,dbo.Customers.Region
      ,dbo.Customers.PostalCode
      ,dbo.Customers.Country
FROM dbo.Customers
INNER JOIN dbo.Orders
ON dbo.Customers.CustomerID = dbo.Orders.CustomerID

Product Sales for 1997

Access

SELECT     Categories.CategoryName 
      ,Products.ProductName
      ,SUM(CCur([Order Details].UnitPrice*[Quantity]*(1-[Discount])/100)*100) AS ProductSales, "Qtr " & DatePart("q",[ShippedDate]) AS ShippedQuarter
FROM (Categories
INNER JOIN Products
ON Categories.CategoryID=Products.CategoryID)
INNER JOIN (Orders
INNER JOIN [Order Details]
ON Orders.OrderID=[Order Details].OrderID)
ON Products.ProductID=[Order Details].ProductID
WHERE Orders.ShippedDate BETWEEN #1/1/1997# AND #12/31/1997#
GROUP BY Categories.CategoryName,
      Products.ProductName, "Qtr " & DATEPART("q",[ShippedDate]);

SQL Server

SELECT     dbo.Categories.CategoryName 
      ,dbo.Products.ProductName
      ,SUM(CONVERT(money, (dbo.[Order Details].UnitPrice * dbo.[Order Details].Quantity) * (1 - dbo.[Order Details].Discount) / 100) * 100) AS ProductSales
FROM dbo.Categories
INNER JOIN dbo.Products
ON dbo.Categories.CategoryID = dbo.Products.CategoryID
INNER JOIN dbo.Orders
INNER JOIN dbo.[Order Details]
ON dbo.Orders.OrderID = dbo.[Order Details].OrderID
ON dbo.Products.ProductID = dbo.[Order Details].ProductID
WHERE dbo.Orders.ShippedDate BETWEEN '19970101' AND '19971231'
GROUP BY dbo.Categories.CategoryName
      ,dbo.Products.ProductName

Products Above Average Price

Access

SELECT     Products.ProductName 
      ,Products.UnitPrice
FROM Products
WHERE (Products.UnitPrice) >
      ( SELECT AVG([UnitPrice])
       From Products
      )
ORDER BY Products.UnitPrice DESC

SQL Server

SELECT     ProductName 
      ,UnitPrice
FROM dbo.Products
WHERE (UnitPrice >
      (
       SELECT AVG(UnitPrice) AS Expr1
       FROM dbo.Products)
      )

Products by Category

Access

SELECT     Categories.CategoryName 
      ,Products.ProductName
      ,Products.QuantityPerUnit
      ,Products.UnitsInStock
      ,Products.Discontinued
FROM Categories
INNER JOIN Products
ON Categories.CategoryID = Products.CategoryID
WHERE ((Products.Discontinued) <> Yes)
ORDER BY Categories.CategoryName,
      Products.ProductName

SQL Server

SELECT     dbo.Categories.CategoryName 
      ,dbo.Products.ProductName
      ,dbo.Products.QuantityPerUnit
      ,dbo.Products.UnitsInStock
      ,dbo.Products.Discontinued
FROM dbo.Categories
INNER JOIN dbo.Products
ON dbo.Categories.CategoryID = dbo.Products.CategoryID
WHERE (dbo.Products.Discontinued <> 1)

Quarterly Orders

Access

SELECT DISTINCT   Customers.CustomerID 
      ,Customers.CompanyName
      ,Customers.City
      ,Customers.Country
FROM [Customers]
RIGHT JOIN Orders
ON Customers.CustomerID = Orders.CustomerID
WHERE Orders.OrderDate Between #1/1/1997# And #12/31/1997#

SQL Server

SELECT DISTINCT   dbo.[Customers].CustomerID 
      ,dbo.[Customers].CompanyName
      ,dbo.[Customers].City
      ,dbo.[Customers].Country
FROM dbo.[Customers]
RIGHT OUTER JOIN dbo.[Orders]
ON dbo.[Customers].CustomerID = dbo.[Orders].CustomerID
WHERE dbo.[Orders].OrderDate BETWEEN '19970101' AND '19971231'

Quarterly Orders By Product

Access

TRANSFORM    SUM(CCur([Order Details].UnitPrice * [Quantity] * (1 - [Discount]) / 100) * 100) AS ProductAmount 
SELECT Products.ProductName
      ,Orders.CustomerID
      ,YEAR([OrderDate]) AS OrderYear
FROM [Products]
INNER JOIN (Orders
INNER JOIN [Order Details]
ON Orders.OrderID = [Order Details].OrderID)
ON Products.ProductID = [Order Details].ProductID
WHERE Orders.OrderDate BETWEEN #1/1/1997# AND #12/31/1997#
GROUP BY Products.ProductName,
      Orders.CustomerID,
      YEAR([OrderDate])
      PIVOT "Qtr " & DATEPART("q",[OrderDate],1,0) In ("Qtr 1","Qtr 2","Qtr 3","Qtr 4")

SQL Server

not provided in SQL Server


Sales by Category

Access

SELECT     Categories.CategoryID 
      ,Categories.CategoryName
      ,Products.ProductName
      ,SUM([Order Details Extended].ExtendedPrice) AS ProductSales
FROM Categories
INNER JOIN (Products
INNER JOIN (Orders
INNER JOIN [Order Details Extended]
ON Orders.OrderID = [Order Details Extended].OrderID)
ON Products.ProductID = [Order Details Extended].ProductID)
ON Categories.CategoryID = Products.CategoryID
WHERE Orders.OrderDate BETWEEN '1/1/1997' AND '12/31/1997'
--WHERE Orders.OrderDate BETWEEN #1/1/1997# AND #12/31/1997# - hashes don't work in SQL Server
GROUP BY Categories.CategoryID,
      Categories.CategoryName,
      Products.ProductName
ORDER BY Categories.CategoryName

SQL Server

SELECT     dbo.Categories.CategoryID 
      ,dbo.Categories.CategoryName
      ,dbo.Products.ProductName
      ,SUM(dbo.[Order Details Extended].ExtendedPrice) AS ProductSales
FROM dbo.Categories
INNER JOIN dbo.Products
INNER JOIN dbo.Orders
INNER JOIN dbo.[Order Details Extended]
ON dbo.Orders.OrderID = dbo.[Order Details Extended].OrderID
ON dbo.Products.ProductID = dbo.[Order Details Extended].ProductID
ON dbo.Categories.CategoryID = dbo.Products.CategoryID
WHERE dbo.Orders.OrderDate BETWEEN '19970101' AND '19971231'
GROUP BY dbo.Categories.CategoryID, dbo.Categories.CategoryName, dbo.Products.ProductName

Sales by Year

Access

PARAMETERS    [Forms]![Sales by Year Dialog]![BeginningDate] DATETIME, 
      [Forms]![Sales by Year Dialog]![EndingDate] DATETIME;
SELECT Orders.ShippedDate,
      ,Orders.OrderID
      ,[Order Subtotals].Subtotal
      ,FORMAT([ShippedDate],"yyyy") AS [Year]
FROM ORDERS
INNER JOIN [ORDER SUBTOTALS]
ON Orders.OrderID = [Order Subtotals].OrderID
WHERE (
       (
        (Orders.ShippedDate) IS NOT NULL
       AND (Orders.ShippedDate) BETWEEN [Forms]![Sales by Year Dialog]![BeginningDate] AND [Forms]![Sales by Year Dialog]![EndingDate]
       )
      )

SQL Server

not provided in SQL Server


Sales Totals by Amount

Access

not provided in Access

SQL Server

SELECT     dbo.[Order Subtotals].Subtotal AS SaleAmount 
      ,dbo.Orders.OrderID
      ,dbo.Customers.CompanyName
      ,dbo.Orders.ShippedDate
FROM dbo.Customers
INNER JOIN dbo.Orders
INNER JOIN dbo.[Order Subtotals]
ON dbo.Orders.OrderID = dbo.[Order Subtotals].OrderID
ON dbo.Customers.CustomerID = dbo.Orders.CustomerID
WHERE dbo.[Order Subtotals].Subtotal > 2500
AND dbo.Orders.ShippedDate BETWEEN '19970101' AND '19971231'

Summary of Sale by Quarter

Access

not provided in Access

SQL Server

SELECT       dbo.Orders.ShippedDate 
            ,dbo.Orders.OrderID
            ,dbo.[Order Subtotals].Subtotal
FROM dbo.Orders
INNER JOIN dbo.[Order Subtotals]
ON dbo.Orders.OrderID = dbo.[Order Subtotals].OrderID
WHERE dbo.Orders.ShippedDate IS NOT NULL

Summary of Sales by Year

Access

not provided in Access

SQL Server

SELECT       dbo.[ORDERS].ShippedDate 
            ,dbo.[ORDERS].OrderID
            ,dbo.[Order Subtotals].Subtotal
FROM dbo.[ORDERS]
INNER JOIN dbo.[ORDER SUBTOTALS]
ON dbo.[ORDERS].OrderID = dbo.[ORDER SUBTOTALS].OrderID
WHERE dbo.[ORDERS].ShippedDate IS NOT NULL

Ten Most Expensive Products

Access

SELECT TOP 10   Products.ProductName AS TenMostExpensiveProducts, 
                Products.UnitPrice
FROM Products
ORDER BY Products.UnitPrice DESC

SQL Server

not provided in SQL Server



© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext