Patika.dev sitesinde PostgreSql sql soruları cevaplarım.
Ödev 1
Aşağıdaki sorgu senaryolarını dvdrental örnek Postgresql veri tabanı üzerinden gerçekleştiriniz.
1_Film tablosunda bulunan title ve description sütunlarındaki verileri sıralayınız.
Select title,description from film;
2_Film tablosunda bulunan tüm sütunlardaki verileri film uzunluğu (length) 60 dan büyük VE 75 ten küçük olma koşullarıyla sıralayınız.
Select * from film where length > 60 and length<75;
3_Film tablosunda bulunan tüm sütunlardaki verileri rental_rate 0.99 VE replacement_cost 12.99 VEYA 28.99 olma koşullarıyla sıralayınız.
Select * from film where rental_rate= 0.99 and replacement_cost= 12.99 or replacement_cost= 28.99;
4_Customer tablosunda bulunan first_name sütunundaki değeri 'Mary' olan müşterinin last_name sütunundaki değeri nedir?
Select last_name from customer where first_name='Mary';
>>>Smith
5_Film tablosundaki uzunluğu(length) 50 ten büyük OLMAYIP aynı zamanda rental_rate değeri 2.99 veya 4.99 OLMAYAN verileri sıralayınız.
Select * from film where length<=50 and rental_rate!=2.99 or rental_rate!=4.99;
veya
Select * from film where length<=50 and not rental_rate=2.99 or not rental_rate=4.99;
Ödev 2
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_Film tablosunda bulunan tüm sütunlardaki verileri replacement cost değeri 12.99 dan büyük eşit ve 16.99 küçük olma koşuluyla sıralayınız ( BETWEEN - AND yapısını kullanınız.)
SELECT * FROM film WHERE replacement_cost>=12.99 AND replacement_cost<16.99;
2_ Actor tablosunda bulunan first_name ve last_name sütunlardaki verileri first_name 'Penelope' veya 'Nick' veya 'Ed' değerleri olması koşuluyla sıralayınız. ( IN operatörünü kullanınız.)
SELECT first_name,last_name FROM actor WHERE first_name IN('Penelope','Nick','Ed');
3_ Film tablosunda bulunan tüm sütunlardaki verileri rental_rate 0.99, 2.99, 4.99 VE replacement_cost 12.99, 15.99, 28.99 olma koşullarıyla sıralayınız.
(IN operatörünü kullanınız.)
SELECT * FROM film WHERE rental_rate IN (0.99,2.99,4.99) AND replacement_cost IN (12.99,15.99,28.99);
Ödev 3
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_Country tablosunda bulunan country sütunundaki ülke isimlerinden 'A' karakteri ile başlayıp 'a' karakteri ile sonlananları sıralayınız.
SELECT country FROM country WHERE country LIKE 'A%a';
2_ Country tablosunda bulunan country sütunundaki ülke isimlerinden en az 6 karakterden oluşan ve sonu 'n' karakteri ile sonlananları sıralayınız.
SELECT country FROM country WHERE country LIKE '_____%n';
3_ Film tablosunda bulunan title sütunundaki film isimlerinden en az 4 adet büyük ya da küçük harf farketmesizin 'T' karakteri içeren verileri sıralayın.
SELECT title FROM film WHERE title ILIKE '%t%t%t%t%';
4_Film tablosunda bulunan tüm sütunlardaki verilerden title 'C' karakteri ile başlayan ve uzunluğu (length) 90 dan büyük olan ve rental_rate 2.99
olan verileri sıralayınız.
SELECT * FROM film WHERE title LIKE 'C%' AND length>90 AND rental_rate=2.99;
Ödev 4
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_Film tablosunda bulunan replacement_cost sütununda bulunan birbirinden farklı değerleri sıralayınız.
SELECT DISTINCT replacement_cost FROM film;
2_ Film tablosunda bulunan replacement_cost sütununda birbirinden farklı kaç tane veri vardır?.
SELECT COUNT(DISTINCT replacement_cost) FROM film;
>>>21
3_ Film tablosunda bulunan film isimlerinde (title) kaç tanesini T karakteri ile başlar ve aynı zamanda rating 'G' ye eşittir?.
SELECT title FROM film where rating='G' AND title LIKE 'T%';
>>>9
4_Country tablosunda bulunan ülke isimlerinden (country) kaç tanesi 5 karakterden oluşmaktadır?.
SELECT COUNT(country) FROM country where country LIKE '_____';
>>>13
5_City tablosundaki şehir isimlerinin kaçtanesi 'R' veya r karakteri ile biter?.
SELECT COUNT(city) FROM city where city ILIKE '%r';
>>>33
Ödev 5
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_film tablosunda bulunan ve film ismi (title) 'n' karakteri ile biten en uzun (length) 5 filmi sıralayınız..
SELECT title FROM film WHERE title LIKE '%n' ORDER BY length DESC LIMIT 5;
2_ film tablosunda bulunan ve film ismi (title) 'n' karakteri ile biten en kısa (length) ikinci 5 filmi sıralayınız.
SELECT title FROM film WHERE title LIKE '%n' ORDER BY length DESC OFFSET 5 LIMIT 5;
3_ customer tablosunda bulunan last_name sütununa göre azalan yapılan sıralamada store_id 1 olmak koşuluyla ilk 4 veriyi sıralayınız..
SELECT * FROM customer WHERE store_id= 1 ORDER BY last_name DESC LIMIT 4;
Ödev 6
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_film tablosunda bulunan rental_rate sütunundaki değerlerin ortalaması nedir?
SELECT AVG(rental_rate) FROM film;
>>>2.9800000000000000
2_ film tablosunda bulunan filmlerden kaçtanesi 'C' karekteri ile başlar?.
SELECT COUNT(title) FROM film WHERE title LIKE 'C%';
>>>92
3_ film tablosunda bulunan filmlerden rental_rate değeri 0.99 a eşit olan en uzun (length) film kaç dakikadır?.
SELECT MAX(length) FROM film WHERE rental_rate=0.99;
>>>184
4_ film tablosunda bulunan filmlerin uzunluğu 150 dakikadan büyük olanlarına ait kaç farklı replacement_cost değeri vardır?.
SELECT COUNT( DISTINCT replacement_cost )FROM film WHERE length > 150;
>>>21
Ödev 7
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_film tablosunda bulunan filmleri rating değerlerine göre gruplayınız.
SELECT rating FROM film GROUP BY rating ;
2_ film tablosunda bulunan filmleri replacement_cost sütununa göre grupladığımızda film sayısı 50 den fazla olan replacement_cost değerini ve karşılık gelen film sayısını sıralayınız.
SELECT replacement_cost,COUNT(*) FROM film GROUP BY replacement_cost HAVING COUNT(*)>50 ;
3_ customer tablosunda bulunan store_id değerlerine karşılık gelen müşteri sayılarını nelerdir?.
SELECT store_id,COUNT(customer) FROM customer GROUP BY store_id ;
4_ city tablosunda bulunan şehir verilerini country_id sütununa göre gruplandırdıktan sonra en fazla şehir sayısı barındıran country_id bilgisini ve şehir sayısını paylaşınız
SELECT country_id,COUNT(city) FROM city GROUP BY country_id ORDER BY COUNT(*) DESC LIMIT 1;
Ödev 8
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_test veritabanınızda employee isimli sütun bilgileri id(INTEGER), name VARCHAR(50), birthday DATE, email VARCHAR(100) olan bir tablo oluşturalım..
CREATE TABLE employee(
id SERIAL PRIMARY KEY,
name VARCHAR(50) NOT NULL,
birthday DATE,
email VARCHAR(100)
);
2_Oluşturduğumuz employee tablosuna 'Mockaroo' servisini kullanarak 50 adet veri ekleyelim
insert into employee (id, name, birthday, email) values (1, 'Jeddy', '2016-11-29', '[email protected]');
insert into employee (id, name, birthday, email) values (2, 'Charmane', '2018-04-16', '[email protected]');
insert into employee (id, name, birthday, email) values (3, 'Meg', '1945-03-07', '[email protected]');
insert into employee (id, name, birthday, email) values (4, 'Emmey', '1980-03-24', '[email protected]');
insert into employee (id, name, birthday, email) values (5, 'Kaia', '1958-07-18', '[email protected]');
insert into employee (id, name, birthday, email) values (6, 'Sonnie', '2004-01-09', '[email protected]');
insert into employee (id, name, birthday, email) values (7, 'Abbot', '1913-10-14', '[email protected]');
insert into employee (id, name, birthday, email) values (8, 'Rahal', '1997-11-29', '[email protected]');
insert into employee (id, name, birthday, email) values (9, 'Elle', '1940-07-25', null);
insert into employee (id, name, birthday, email) values (10, 'Leodora', '2003-06-14', null);
insert into employee (id, name, birthday, email) values (11, 'Udell', null, '[email protected]');
insert into employee (id, name, birthday, email) values (12, 'Leticia', null, '[email protected]');
insert into employee (id, name, birthday, email) values (13, 'Rolland', '2020-05-29', null);
insert into employee (id, name, birthday, email) values (14, 'Zora', '2009-03-04', null);
insert into employee (id, name, birthday, email) values (15, 'Andriana', '1954-02-21', '[email protected]');
insert into employee (id, name, birthday, email) values (16, 'Aubert', '1942-12-23', '[email protected]');
insert into employee (id, name, birthday, email) values (17, 'Mikol', null, '[email protected]');
insert into employee (id, name, birthday, email) values (18, 'Kirk', '1910-01-13', '[email protected]');
insert into employee (id, name, birthday, email) values (19, 'Margeaux', '1999-06-09', '[email protected]');
insert into employee (id, name, birthday, email) values (20, 'Katerine', '2017-01-23', '[email protected]');
insert into employee (id, name, birthday, email) values (21, 'Winnifred', '1917-02-01', '[email protected]');
insert into employee (id, name, birthday, email) values (22, 'Rozanna', '1936-06-22', '[email protected]');
insert into employee (id, name, birthday, email) values (23, 'Priscilla', null, '[email protected]');
insert into employee (id, name, birthday, email) values (24, 'Chucho', '1961-05-20', '[email protected]');
insert into employee (id, name, birthday, email) values (25, 'Sue', '1904-02-12', null);
insert into employee (id, name, birthday, email) values (26, 'Deborah', '1913-08-30', '[email protected]');
insert into employee (id, name, birthday, email) values (27, 'Tarrah', '1941-05-05', '[email protected]');
insert into employee (id, name, birthday, email) values (28, 'Talbot', '2002-08-08', null);
insert into employee (id, name, birthday, email) values (29, 'Merna', '1970-05-03', null);
insert into employee (id, name, birthday, email) values (30, 'Elna', null, '[email protected]');
insert into employee (id, name, birthday, email) values (31, 'Deidre', '1988-05-19', '[email protected]');
insert into employee (id, name, birthday, email) values (32, 'Emile', '2009-09-12', '[email protected]');
insert into employee (id, name, birthday, email) values (33, 'Trefor', null, '[email protected]');
insert into employee (id, name, birthday, email) values (34, 'Donica', '1923-10-11', null);
insert into employee (id, name, birthday, email) values (35, 'Christin', '1932-09-01', '[email protected]');
insert into employee (id, name, birthday, email) values (36, 'Jamima', '1975-07-28', null);
insert into employee (id, name, birthday, email) values (37, 'Mozelle', null, '[email protected]');
insert into employee (id, name, birthday, email) values (38, 'Heriberto', '1985-04-24', '[email protected]');
insert into employee (id, name, birthday, email) values (39, 'Leyla', '1966-10-02', null);
insert into employee (id, name, birthday, email) values (40, 'Blondie', '1964-04-21', null);
insert into employee (id, name, birthday, email) values (41, 'Lana', null, '[email protected]');
insert into employee (id, name, birthday, email) values (42, 'Devin', '1991-07-20', '[email protected]');
insert into employee (id, name, birthday, email) values (43, 'Darda', '1942-08-11', '[email protected]');
insert into employee (id, name, birthday, email) values (44, 'Guinna', '1954-04-02', '[email protected]');
insert into employee (id, name, birthday, email) values (45, 'Eda', null, null);
insert into employee (id, name, birthday, email) values (46, 'Marshal', '1990-11-10', '[email protected]');
insert into employee (id, name, birthday, email) values (47, 'Halsey', '1963-09-23', '[email protected]');
insert into employee (id, name, birthday, email) values (48, 'Charlena', '1914-02-12', null);
insert into employee (id, name, birthday, email) values (49, 'Gerda', '1986-08-25', '[email protected]');
insert into employee (id, name, birthday, email) values (50, 'Paolina', '2011-05-09', '[email protected]');
3_ Sütunların her birine göre diğer sütunları güncelleyecek 5 adet UPDATE işlemi yapalım..
UPDATE employee
SET name = 'Mayak'
WHERE id = 1;
UPDATE employee
SET name = 'Kayak'
WHERE id = 2;
UPDATE employee
SET name = 'Dayak'
WHERE id = 3;
UPDATE employee
SET name = 'Bayak'
WHERE id = 4;
UPDATE employee
SET name = 'Sayak'
WHERE id = 5;
4_ Sütunların her birine göre ilgili satırı silecek 5 adet DELETE işlemi yapalım.
DELETE FROM employee
WHERE id IN (6,7,8,9,10);
Ödev 9
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_City tablosu ile country tablosunda bulunan şehir (city) ve ülke (country) isimlerini birlikte görebileceğimiz INNER JOIN sorgusunu yazınız.
SELECT city.city,country.country FROM country INNER JOIN city ON city.country_id=country.country_id;
2_ Customer tablosu ile payment tablosunda bulunan payment_id ile customer tablosundaki first_name ve last_name isimlerini birlikte görebileceğimiz
INNER JOIN sorgusunu yazınız.
SELECT customer.first_name, customer.last_name,payment_id FROM payment
INNER JOIN customer ON customer.customer_id=payment.customer_id;
3_ Customer tablosu ile rental tablosunda bulunan rental_id ile customer tablosundaki first_name ve last_name isimlerini birlikte görebileceğimiz
INNER JOIN sorgusunu yazınız.
SELECT customer.first_name, customer.last_name,rental.rental_id FROM customer
INNER JOIN rental ON rental.customer_id=customer.customer_id;
Ödev 10
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_city tablosu ile country tablosunda bulunan şehir (city) ve ülke (country) isimlerini birlikte görebileceğimiz LEFT JOIN sorgusunu yazınız..
SELECT city,country FROM country
LEFT JOIN city ON city.country_id=country.country_id;
2_ customer tablosu ile payment tablosunda bulunan payment_id ile customer tablosundaki first_name ve last_name isimlerini birlikte görebileceğimiz
RIGHT JOIN sorgusunu yazınız.
SELECT customer.first_name,customer.last_name,payment.payment_id FROM customer
RIGHT JOIN payment ON payment.customer_id=customer.customer_id;
3_ customer tablosu ile rental tablosunda bulunan rental_id ile customer tablosundaki first_name ve last_name isimlerini birlikte görebileceğimiz
FULL JOIN sorgusunu yazınız.
SELECT customer.first_name,customer.last_name,payment.payment_id FROM customer
FULL JOIN payment ON payment.customer_id=customer.customer_id;
Ödev 11
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_actor ve customer tablolarında bulunan first_name sütunları için tüm verileri sıralayalım..
SELECT customer.first_name,actor.first_name FROM customer FULL JOIN actor ON actor.first_name=customer.first_name;
2_ actor ve customer tablolarında bulunan first_name sütunları için kesişen verileri sıralayalım.
SELECT customer.first_name,actor.first_name FROM customer INNER JOIN actor ON actor.first_name=customer.first_name;
3_ actor ve customer tablolarında bulunan first_name sütunları için ilk tabloda bulunan ancak ikinci tabloda bulunmayan verileri sıralayalım..
SELECT customer.first_name,actor.first_name FROM customer LEFT JOIN actor ON actor.first_name=customer.first_name;
4_ İlk 3 sorguyu tekrar eden veriler için de yapalım.
(SELECT customer.first_name FROM customer)UNION(SELECT actor.first_name FROM actor);
(SELECT customer.first_name FROM customer)INTERSECT ALL(SELECT actor.first_name FROM actor);
(SELECT customer.first_name FROM customer)EXCEPT ALL(SELECT actor.first_name FROM actor);
Ödev 12
Aşağıdaki sorgu senaryolarını dvdrental örnek veri tabanı üzerinden gerçekleştiriniz.
1_film tablosunda film uzunluğu length sütununda gösterilmektedir. Uzunluğu ortalama film uzunluğundan fazla kaç tane film vardır?.
SELECT title FROM film WHERE length>(
SELECT AVG(length) FROM film
);
2_ film tablosunda en yüksek rental_rate değerine sahip kaç tane film vardır?
SELECT COUNT(title) FROM film WHERE rental_rate=(
SELECT MAX(rental_rate) FROM film
);
>>>336
3_ film tablosunda en düşük rental_rate ve en düşük replacement_cost değerlerine sahip filmleri sıralayınız.
(SELECT film.title FROM film WHERE rental_rate=(SELECT MIN(rental_rate)FROM film))
UNION
(SELECT film.title FROM film WHERE rental_rate=(SELECT MIN(replacement_cost)FROM film));
4_ payment tablosunda en fazla sayıda alışveriş yapan müşterileri(customer) sıralayınız.
SELECT customer_id FROM payment GROUP BY customer_id ORDER BY COUNT(*) DESC;