37
Lekérdezések az SQL SELECT utasítással

Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Embed Size (px)

Citation preview

Page 1: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Lekérdezések azSQL SELECTutasítással

Page 2: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Célok

• Az SQL SELECTutasítás lehetőségeinek bemutatása

• A megjelenítendő oszlopok kiválasztása• Elemi SELECTutasítások végrehajtása

• Az SQL utasítások és az iSQL*Plus parancsok megkülönböztetése

Page 3: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Az SQL SELECTutasítás lehetőségei

KiválasztásVetítés

1. tábla 2. tábla

1. tábla1. tábla

Összekapcsolás

Page 4: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Elemi SELECTutasítások

• A SELECTa megjelenítendő oszlopokat azonosítja• A FROMaz oszlopokat tartalmazó táblákat azonosítja

* összes oszlop

DISTINCT ismétlődések elnyomása column|expression megadott oszlop vagy kifejezés értékealias másodnév

table táblanév

Például a dolgozók tábla összes adatának kilistázása:SELECT * FROM employees

SELECT *|{[DISTINCT] column| expression [ alias],...}FROM table;

Page 5: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Összes oszlop kiválasztása

SELECT *FROM departments;

A fenti utasítás ekvivalens a következővel:SELECT department_id, department_name, manager_id,location_idFROM departments;

Page 6: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Meghatározott oszlopok kiválasztása

SELECT department_id, location_idFROM departments;

Adjuk meg az összes osztálynak és a címének az azonosítóját!

– Az oszlopokat vesszővel választjuk el a listában.

– Számít a sorrend!

Page 7: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

SQL utasítások

• Kis/nagy betűre nem érzékenyek.

• Lehetnek egy vagy több sorosak.

• Kulcsszavak nem rövidíthetők és sorok között nem elvághatók.

• A SELECT és FROM listákat általában külön sorba írjuk.

• Bekezdések növelik az olvashatóságot.

• iSQL*Plus: az SQL utasítás opcionálisan pontosvesszővel zárható le. Ha több SQL utasítás van, akkor a pontosvessző

kötelező közöttük. (Az Execute gombbal hajtható végre!)

• SQL*plus: minden egyes SQL utasítást pontosvesszővel kell lezárni. (Az ENTER-re hajtja végre!)

Page 8: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Oszlop fejléc alapértelmezések• iSQL*Plus:

– Alapértelmezett fejléc-igazítás: Középre

– Alapértelmezett fejléc-megjelenítés: Nagybetű

• SQL*Plus:– Karakterlánc és Dátum típusú oszlop fejléce: Balraigazított– Numerikus oszlop fejléce: Jobbraigazított– Alapértelmezett fejléc-megjelenítés: Nagybetű

SELECT last_name, hire_date, salaryFROM employees;

…iSQL*Plus- ban:

Page 9: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Aritmetikai kifejezések

Az aritmetikai kifejezés (számított oszlop) tartalmazhat oszlopnevet, konstanst, és aritmetikai műveletet.A numerikus és dátum típusra alkalmazható aritmetikai műveletek:

(DATE,TIMESTAMP adattípusra csak + és - !)

Művelet Jelentés

+ Összeadás

- Kivonás

* Szorzás

/ Osztás

Az aritmetikai műveletek az SQL utasítás bármelyik részében megengedettek, kivéve a FROM listát!

Page 10: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

SELECT last_name, salary, salary + 300FROM employees;

Aritmetikai műveletek használata(számított oszlop)

Kiértékelési sorrend:1. Szorzás, osztás majd összeadás, kivonás.2. Azonos prioritás esetén balról jobbra értékeljük ki.3. Zárójelekkel felülírható, vagy egyértelművé tehető a

sorrend.

Mennyi lenne a 300-zal növelt fizetés?

A számított oszlopot a tábla nem tárolja, csak az eredményben látszik.

Page 11: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

SELECT last_name, salary, 12*salary+100FROM employees;

Műveletek kiértékelési sorrendje

SELECT last_name, salary, 12*(salary+100)FROM employees;

1

2

1. Először a szorzás, majd az összeadás

(ugyanaz, mint (12*salary)+100 ):

2. Először az összeadás, majd a szorzás.

Page 12: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Nullérték• A nullérték: hiányzó, nem elérhető, nem garantált,

ismeretlen, nem alkalmazható érték.• A nullérték nem egyenlő 0-val vagy az üres karakterlánccal!

SELECT last_name, job_id, salary, commission_pctFROM employees;

Csak a kereskedelmi igazgatónak (SA_MAN) és a kereskedőnek (SA_REP) lehet jutaléka (commission_pct), mindenki másnak nullérték szerepel hiányzó értékként.

Page 13: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

SELECT last_name, 12*salary*commission_pctFROM employees;

Nullértékaritmetikai kifejezésekben

Nullértéket tartalmazó aritmetikai kifejezés kiértékelésének eredménye nullérték!

Page 14: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Oszlopok másodnevének megadása

Az oszlop másodneve:• az oszlop fejlécét is átnevezi, • számított oszlop esetén különösen hasznos,• az oszlopnevet (szóközzel elválasztva) követi

(opcionálisan az AS kulcsszó is használható).• Dupla idézőjelbe kell tenni, ha szóközt vagy

speciális karaktert (#, $, …) használunk, illetve ha nem csupa nagybetűből áll.

Page 15: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Oszlopok másodnevének használata

SELECT last_name "Name" , salary*12 "Annual Salary"FROM employees;

SELECT last_name AS name, commission_pct commFROM employees;

A kisbetűk és szóköz miatt kettős idézőjel kell!

A másodnév előtt AS kulcsszó is használható.

Page 16: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Összefűzés (konkatenálás) művelet

Az összefűzés (konkatenálás) művelet:• Oszlopokat vagy karakterláncokat kapcsol össze

egyetlen oszloppá.• Jelölése: ||• Az eredményoszlop egy karakterkifejezés.• Karakterlánc||null eredménye a karakterlánc!

SELECT last_name||job_id AS "Employees"FROM employees;

Page 17: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Literálok

• A literál olyan karakteres, vagy numerikus, vagy dátumtípusú érték, amely a SELECTlistában előfordul.

• A dátumtípusú és a karakteres literál értékét szimpla idézőjelek közé kell tenni.

• Minden egyes visszaadott sorban megjelenik az adott érték.

Page 18: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Literálok használata

SELECT last_name ||' is a '||job_idAS "Employee Details"

FROM employees;

Olvashatóbbá tehetjük a listát!

Page 19: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

A Quote (q) művelet• Saját idézőjelet definiálhatunk vele.• Tetszőleges határoló karakter választható.• Határoló lehet a következő párok valamelyike is: [ ] { } ( ) < >• Növeli az olvashatóságot és a használhatóságot is.

SELECT department_name || q'[, it's assigned Manager Id: ]' || manager_idAS "Department and Manager"

FROM departments;

Page 20: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Ismétlődő SorokA lekérdezések eredménye alapértelmezésben multihalmaz(bag), azaz tartalmazhat ismétlődő sorokat.DISTINCT kulcsszó: szűri az ismétlődő sorokat.1: összes osztálykód, 2: összes különböző osztálykód

SELECT department_idFROM employees;

SELECT DISTINCT department_idFROM employees;

1

2

Page 21: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

SQL és iSQL*Plus

SQL utasítások

A lekérdezés eredményeiSQL*Plusparancsok

Kliens

Formázott jelentések

Internet böngésző

Oracleszerver

(Az eredmény HTML fájlba menthető.)

Page 22: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

SQL utasítások kontraiSQL*Plus parancsok

SQLutasítások

SQL • Egy nyelv• ANSI standard• Kulcsszavak nem

rövidíthetők

iSQL*Plus• Egy környezet• Oracle szabadalom• Kulcsszavak rövidíthetők• Böngészőben fut• Központilag betöltött;

nem kell az egyes gépekre telepíteni

iSQL*Plusparancsok

Page 23: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Az iSQL*Plus áttekintéseAz iSQL*Plus-ba bejelentkezés után:• Leírás kérhető a táblák szerkezetéről • SQL utasítások szerkeszthetők, végrehajthatók• Kiírhatók fájlba (szkript) az SQL utasítások• A fájlba kimentett SQL utasítások betölthetők, vagy

végrehajthatók• Az iSQL*Plus utasítások osztályozása:

– A környezet beállítása– Az SQL utasításokra vonatkozó általános beállítások– Az eredmény formázása– Az SQL utasítások küldése a böngészőből az Oracle

szerverhez– SQL utasítások szerkesztése– Változók definiálása, megjelenítése, átadása SQL

utasításoknak

Page 24: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Bejelentkezés iSQL*Plus-ba

Kedvenc böngésződből:http://ablinux.inf.elte.hu:5560/isqlplus/

Connect Identifier: oradb

Page 25: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Az iSQL*Plus környezet

6

3 4 5

1

2

8 9

7

Page 26: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

A táblaszerkezet megjelenítése

Az iSQL*Plus DESCRIBEparancsa használható az adott tábla, nézet vagy szinonima szerkezetének megjelenítésére:

DESC[RIBE] tablename

Az eredmény a tábla sémáját adja meg

(oszlop, lehet nullérték benne vagy nem, típus) formában.

Page 27: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

A táblaszerkezet megjelenítéseDESCRIBE employees

Adattípus Leírás

NUMBER(p, s)

Maximum p jegyű szám, s tízedesjeggyel

VARCHAR2(s) Maximum s hosszú, változó hosszú karakteres érték

DATE i.e. 4712 január 1. és i.sz. 9999. december 31. közé eső

dátum.

CHAR(s) s hosszú karakteres érték

Elemi adattípusok:

Page 28: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Szkriptfájlok használata

SELECT last_name, hire_date, salaryFROM employees; 1

2

Az utasítás begépelése

Az utasítás mentése

A szkriptfájlok kiterjesztése: .sql

Page 29: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Szkriptfájlok használata

Page 30: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Szkriptfájlok használata

1 Betöltés

Page 31: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Szkriptfájlok használata

2

3

D:\TEMP\emp_data.sql

A szkriptfájl helye

Betöltés

Page 32: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Az iSQL*Plus történet lapja

1

2

3T

öltsü

k be a

mu

nkaterü

letre!Jelöljük be azokat az utasításokat, amelyeket újra akarunk futtatni!

Váltsu

nk át a m

un

katerület lap

ra!

Page 33: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Az iSQL*Plus történet lapja

3

4

Váltsu

nk át a m

un

katerület lap

ra!

Hajtsuk végre a bemásolt utasításokat!

Page 34: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Az iSQL*Plus környezeti és egyéb paramétereinek beállítása

2

3

1

Beállítások (preferenciák)

A k

ateg

óri

a ki

vála

sztá

sa

Állítsuk be a kívánt paramétert!

Page 35: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Az eredmény kimeneti helyének beállítása

1

2

Az input alatt jelenjen meg vagy egy HTML fájlba mentsük?

Alkalmazás

Page 36: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Összefoglalás

Ebben a részben megtanultuk: • hogyan írjunk olyan SELECTutasítást, amely:

– visszaadja egy tábla összes sorát és oszlopát,– visszaadja a megadott oszlopait egy táblának,– oszlop-másodneveket használ a kifejezőbb és

beszédesebb oszlop-fejlécek elérésére,

• az iSQL*Plus környezet használatát SQL utasítások és iSQL*Plus parancsok írására, végrehajtására, elmentésére és betöltésére.

SELECT *|{[DISTINCT] column|expression [ alias],...}FROM table;

Page 37: Lekérdezések az SQL SELECT utasítással - ELTE IKpeople.inf.elte.hu/kiss/08abe1/HLes01.pdf · Elemi SELECT utasítások • A SELECT a megjelenítendő oszlopokat azonosítja •

Feladatok1. A következő utasítás több hibát tartalmaz. Melyek ezek?

SELECT employee_id, last_namesal x 12 ANNUAL SALARYFROM employees;

2. Jelenítsük meg az osztályok (departments) tábla sémáját és tartalmát!

3. Adjuk meg a dolgozók (employees) vezetéknevét (last_name), beosztási kódját (job_id), belépési dátumát (hire_date) és azonosítóját (employee_id) úgy, hogy az azonosító legyen az első oszlop, és a belépési dátum neve STARTDATE legyen!Mentsük el egy lab_01_07.sql fájlba a megoldást!

4. Adjuk meg az összes különböző beosztási kódot (job_id)!5. Fűzzük össze a vezetékneveket (last_name) a beosztási kóddal

(job_id), úgy hogy köztük egy vessző és egy szóköz legyen, és az új oszlop neve Employee and title legyen!