Kategoria: T-SQL

Zadanie 5.

Pokaż pierwsze i ostatnie zamówienie dla klientów z Niemiec.

Baza: Northwind, Tabele: dbo.Orders, dbo.Customers, Kolumny: CustomerID, OrderID, Country, Wynik: 11 rows

s5

Rozwiązanie

SELECT CustomerID, MIN(OrderID) as FirstOrder, MAX(OrderID) as LastOrder
FROM dbo.Orders
GROUP BY CustomerID
HAVING CustomerID in (SELECT CustomerID FROM dbo.Customers WHERE Country = 'Germany')
ORDER BY CustomerID;

[collapse]

Zadanie 4.

Wybierz tylko parzyste numery zamówień z zakresu 10759 – 10924, które złożyli klienci z USA. Nie używaj złączenia tabel.

Baza: Northwind, Tabele: dbo.Orders, dbo.Customers, Kolumny: OrderID, CustomerID, Country, Wynik: 9 rows

s4

Rozwiązanie

SELECT OrderID, CustomerID
FROM dbo.Orders
WHERE (OrderID %2 = 0) AND (OrderID BETWEEN 10759 AND 10924)
AND CustomerID in (SELECT CustomerID FROM dbo.Customers WHERE Country = 'USA');

[collapse]

Zadanie 3.

Pokaż klientów, którzy w 1996 roku nie złożyli żadnego zamówienia, ale złożyli je później. Zadanie rozwiąż na dwa różne sposoby.

Baza: Northwind, Tabela: dbo.Orders, Kolumny: CustomerID, OrderDate, Wynik: 22 rows

s3

Rozwiązanie

1) z grupowaniem:

SELECT CustomerID
FROM dbo.Orders
GROUP BY CustomerID
HAVING MIN(OrderDate) >= '19970101';

2) z użyciem podzapytań:

SELECT DISTINCT O.CustomerID
FROM dbo.Orders as O
WHERE O.CustomerID not in (SELECT o1.CustomerID FROM dbo.Orders as o1 WHERE o1.OrderDate >= '19960101' AND o1.OrderDate < '19970101')
AND O.CustomerID in (SELECT o2.CustomerID FROM dbo.Orders as o2 WHERE o2.OrderDate >= '19970101')
ORDER BY O.CustomerID;

[collapse]

Zadanie 1.

Wyznacz id klienta, który złożył ostatnie zamówienie (najnowsze). Zadanie rozwiąż na dwa różne sposoby.

Baza: Northwind, Tabela: dbo.Orders, Kolumny: CustomerID, OrderID, Wynik: 1 row

s1

Rozwiązanie

1) z użyciem funkcji OFFSET-FETCH, ewentualnie TOP:

SELECT CustomerID, OrderID
FROM dbo.Orders
ORDER BY OrderID DESC
OFFSET 0 ROWS FETCH NEXT 1 ROW ONLY;

2) z użyciem podzapytania:

SELECT CustomerID, OrderID
FROM dbo.Orders
WHERE OrderID = ( SELECT Max(OrderID) FROM dbo.Orders );

[collapse]

Zadanie 12.

Z tabeli Products wybierz (ProductID, ProductName) produkty:

a) należące do kategorii nr 7

b) takie, gdzie cena jednostkowa jest większa niż 15

c) w cenie do 10 lub powyżej 50

d) których nazwa na drugim miejscu ma literę ‚e’

Baza: Northwind, Tabela: dbo.Products, Kolumny: ProductID, ProductName, CategoryID, UnitPrice, , Wyniki: a) 5 rows, b) 51 rows, c) 18 rows, d) 5 rows

Rozwiązanie

SELECT ProductID, ProductName

FROM dbo.Products

a) WHERE CategoryID = 7

b) WHERE UnitPrice > 15

c) WHERE UnitPrice < 10 OR UnitPrice > 50

d) WHERE ProductName LIKE '_e%'

[collapse]

Zadanie 11.

Z tabeli Orders wybierz (OrderID, CustomerID) zamówienia:

a) dostarczone między 1 maja a 15 października 1997

b) dostarczone do Australii, Niemiec i Wielkiej Brytanii

c) obsługiwane przez przewoźnika o id 2

d) dostarczone do miast, których nazwa zaczyna się na litery od A, B, C i D

Baza: Northwind, Tabela: dbo.Orders, Kolumny: OrderID, CustomerID, ShippedDate, ShipCountry, ShipVia, ShipCity, Wynik: a) 184 rows, b) 178 rows, c) 326 rows, d) 271 rows

Rozwiązanie

SELECT OrderID, CustomerID

FROM dbo.Orders

a) WHERE ShippedDate >= '19970501' AND ShippedDate < '19971016'

lub inaczej: WHERE ShippedDate BETWEEN '19970501' AND '19971015'

b) WHERE ShipCountry in('Australia', 'Germany', 'UK')

lub: WHERE ShipCountry = 'Australia' or ShipCountry = 'Germany' or ShipCountry = 'UK'

c) WHERE ShipVia = 2

d) WHERE ShipCity LIKE '[A-D]%'

[collapse]

Zadanie 10.

Z tabeli Employees (EmployeeID, FirstName, LastName) wybierz:

a) pracowników z UK

b) pracowników, którzy nie są z Londynu

c) urodzeni po 1960 roku

d) wszystkich panów

Baza: Northwind, Tabela: dbo.Employees, Kolumny: EmployeeID, FirstName, LastName, Country, City, BirthDate, TitleOfCourtesy, Wynik: a) 4 rows, b) 5 rows, c) 3 rows, d) 3 rows

Rozwiązanie

SELECT EmployeeID, FirstName, LastName

FROM dbo.Employees

a) WHERE Country = 'UK'

b) WHERE City <> 'London'

c) WHERE BirthDate > '19610101'

d) WHERE TitleOfCourtesy = 'Mr.'

[collapse]

Zadanie 28.

Podsumuj pracę przewoźników: podlicz, ile zamówień obsłużyli w każdym roku. W wyniku zaznacz, na którym miejscu jest dany przewoźnik w ilości obsłużonych zamówień.

Baza: Northwind, Tabele: dbo.Orders, dbo.Shippers, Kolumny: CompanyName, OrderDate, ShipVia, ShipperID, Wynik: 9 rows

37

Rozwiązanie

SELECT ROW_NUMBER() OVER(PARTITION BY YEAR(O.OrderDate) ORDER BY COUNT(*) DESC) as Nr, S.CompanyName, YEAR(O.OrderDate) as Year, COUNT(*) as Orders
FROM dbo.Orders as O
JOIN dbo.Shippers as S on O.ShipVia = S.ShipperID
GROUP BY S.CompanyName, YEAR(O.OrderDate)
ORDER BY Year, Orders DESC;

[collapse]

Zadanie 9.

Z tabeli klientów wybierz kraj, miasto i nazwę firmy. Nazwa kraju ma zaczynać się literą A lub B.

Baza: Northwind, Tabela: dbo.Customers, Kolumny: Country, City, CompanyName, Wynik: 16 rows

36

Rozwiązanie

SELECT Country, City, CompanyName
FROM dbo.Customers
WHERE Country LIKE '[A-B]%'
ORDER BY Country, City;

[collapse]
« Starsze wpsiy Recent Entries »