SQL je strukturirani jezik upita. Stvorena je posebno za upravljanje i pristup podacima koji se nalaze u relacijskim bazama podataka. Prvi komercijalni pothvat koji je koristio SQL bio je Oracle koji i dalje ima svoj jezik upita SQL * Plus kao osnova cijelog svog sustava upravljanja relacijskim bazama podataka (RDMS).
Danas MySQL, SQL Server, SAP i Sybase svi koriste SQL za pristup bazi podataka. U ovom ćemo vam vodiču dati standardnu verziju SQL naredbi, obraćajući posebnu pozornost na Oracle implementaciju u SQL * Plus.
IZBOR UREDNIKA: Preporučujemo alate za upravljanje infrastrukturom SolarWinds za nadzor svih vaših Microsoftovih alata, uključujući SQL Server. Potreban vam je paket alata za nadzor koji mogu komunicirati kako biste obuhvatili sve sadržaje koji podržavaju vašu relacijsku bazu podataka.
Relacijske baze podataka
SQL upravlja relacijske baze podataka. Relacijska baza podataka sadrži tablice koje su odvojene kako bi se smanjilo ponavljanje podataka. Proces odlučivanja o pravilnom grupiranju kategorija podataka naziva se “normalizacija.“U nekim slučajevima, zahtjevi za performansama mogu nalagati da tablice rade bolje ako nisu u potpunosti normalizirane. Ovaj se proces naziva “denormalizacija” i rijetka je pojava.
Svaka tablica treba stupac koji jedinstveno identificira svaki redak. To se naziva “Osnovni ključ.”Ostale tablice koje se mogu pridružiti tom entitetu moraju sadržavati referencu na primarni ključ u svakom zapisu. Ta se referenca naziva “strani kljuc.”Vi pridružiti tablice zajedno podudaranjem stranog ključa u jednoj tablici s primarnim ključem u drugoj. Ova radnja se izvodi sa SQL-om. Dijagram odnosa odnosa između entiteta korisna je referenca kada odlučujete o strukturiranju SQL izraza.
Da biste ubrzali pristup, normalno je staviti an indeks na svaki primarni ključ u bazi podataka. Moguće je i pohranjivanje često korištenih pridruživanja za stvaranje virtualnih tablica koje se nazivaju “pregleda.”
Još jedan objekt baze podataka je a okidač. Ovo je dio SQL-a koji se pokreće kad god se vrijednost doda u stupac ili promijeni. Okidač će ažurirati vrijednosti u stupcu u drugoj tablici ili drugim stupcima u istoj tablici. To se događa ako se u stupcu na koji je postavljen okidač dodana ili promijenjena vrijednost. Također može ograničiti vrijednosti koje se mogu unijeti u stupac.
DQL, DDL, DCL i DML
SQL uključuje četiri podskupine naredbi. Ovi su Jezik upita podataka (DQL), Jezik opisa podataka (DDL), Jezik kontrole podataka (DCL), i Jezik manipulacije podacima (DML).
Na većini projekata Administrator baze podataka (DBA) je jedini član tima koji ima povlastice DDL. Ova naredbena skupina stvara, mijenja i ispušta tablice, indekse, okidače i prikaze.
DML koristi se za dodavanje, promjenu ili uklanjanje zapisa iz tablica u bazi podataka. Pristup ovim SQL funkcijama obično je ograničen na pomoćno osoblje ili starije, odgovorne članove korisničke zajednice.
DQL koristi se za generiranje izvješća iz baze podataka. Ovaj podskup naredbi koriste programeri i mogu biti dostupni krajnjim korisnicima kako bi mogli izvršavati vlastite upite.
Upravljanje korisničkim povlasticama pohranjuje se u istoj bazi podataka kao i podaci. Međutim, pristup ovim tablicama obično je ograničen na DBA. Upravljanje pristupom korisniku sve se provodi kroz DCL.
Postoji jedna korisna SQL naredba koja ne spada u klasifikacije DQL, DDL, DCL ili DML. Ovo je “opisati“Koja se obično provodi kao DESC. To pokazuje strukturu objekta u bazi podataka. U slučaju tablice prikazat će popis stupaca te vrstu i veličinu podataka. Pokazat će SQL koji je stvorio prikaz ili okidač i stupce koji su uključeni u određeni indeks.
Relacijski operatori
Teorija iza relacijskih baza podataka definirana je s E. F. Codd 1970. U Coddovoj definiciji leži zahtjev alata za ispitivanje koji mora implementirati osam bitnih relacijskih operacija. Ovi su:
- ODABERI
- PROJEKT
- PRIDRUŽITI
- PROIZVOD
- UNIJA
- presjeći
- RAZLIKA
- PODIJELITI
Morate savladati svaku od tih operacija kako biste učinkovito pristupili podacima iz relacijske baze podataka. To su objašnjena u nastavku.
ODABERI
SELECT se izvorno zvao OGRANIČITI. To je mogućnost izdvajanja jednog zapisa ili grupe odgovarajućih zapisa iz tablice u bazi podataka. Kao i teorijska operacija, ODABERI je ime glavne naredbe u bilo kojoj SQL implementaciji. Zapravo, sve pronalaženje podataka vrši se SELECT. Naredba je toliko moćna da se može mijenjati na mnogo, mnogo načina. Većina SQL-a koje ćete morati naučiti jesu “klauzule” na SELECT izjavi.
PROJEKT
PROJEKT je sposobnost izoliranja stupca (ili “atributa”) u tablici. Uvijek se provodi s stavkom SELECT.
PRIDRUŽITI
PRIDRUŽITE se povezuje tablice na zajednički atribut. Strani ključ u jednoj tablici koristite za podudaranje s vrijednostima primarnog ključa u drugoj tablici. Akt učinkovito objedinjuje dvije tablice. To se implementira kao klauzula u izrazu SELECT. Spajanje između dvije tablice automatski će izostaviti sve zapise koji se ne pojavljuju u obje potporne tablice. A “vanjski spoj“Prikazat će zapise koji nemaju podudaranje u drugoj tablici, a polja koja bi trebala imati druga tablica ostavljaju prazna.
PROIZVOD
PROIZVOD je također poznat i kao “puta.”Ovo se implementira kao SELECT izjava koja crpi podatke iz dvije tablice, ali ne određuje spajanje između njih. U stvarnom životu postoji vrlo malo praktičnih razloga zašto bi itko ikad izveo dva stola. Obično je znak upozorenja da ste loše napisali klauzulu JOIN. Rezultat PROIZVODA je da se svaki kvalificirani zapis u jednoj tablici podudara sa svakim kvalificiranim zapisom u drugoj tablici. Dakle, ako stvorite SELECT izjavu iz dvije tablice, od kojih svaka ima deset zapisa, rezultati će biti ukupno 100 zapisa.
UNIJA
UNION je čest operator u teoriji skupova. Ako imate dva seta, sindikat kombinira sve članove oba skupa. Umnožavanje uklanja se iz rezultata. U SQL-u to implementira ILI Boolov operator.
presjeći
INTERSECT je drugi glavni operator teorije skupova. Ako imate dva skupa, sjecište opisuje one predmete koji su članovi oba skupa. Bilo koji predmet koji je član samo jednog od dva skupa isključen je iz rezultata. U SQL-u to implementira I Boolov operator.
RAZLIKA
RAZLIKA je poznata i kao “minus“, A u notaciji je predstavljen znakom minus (” – “). Nekoliko je načina provedbe RAZLIKE. Može se stvoriti uključivanjem boola NE u kriterijima za odabir te ga također može provesti a MINUS operatera nakon čega slijedi podupitnik.
PODIJELITI
DIVIDE je neobična operacija koja, poput PRODUCT-a, ima vrlo malo praktične primjene. Codd je DIVIDE smatrao kiselinskim testom bilo kojeg relacijskog sustava i njegovog alata za upite, tako da svaka SQL implementacija uključuje tu mogućnost samo da bi se kvalificirala za naslov “relacijska”. U stvarnosti, nikad je nećete koristiti. Provedba DIVIDE zahtijeva niz podupitava koji se unose u MINUS u Oracle SQL * Plus i an OSIM operatora u nekim drugim implementacijama SQL-a, kao što su SQL Server i PostgreSQL.
Bulovi operateri
George Boole bio je britanski matematičar koji je umro 1864. Izumio je Booleovu algebru koja nije imala praktičnu primjenu sve dok se polja informatike i relacijske baze podataka nisu pojavila u kasnom 20. stoljeću. Booleova algebra središnja je rad u SQL-u – mogli ste pisati najosnovnije SQL upite bez korištenja logike logike. Boolova logika također podupire sve tražilice. Ključni Booleovi operateri u SQL-u su:
- I
- ILI
- NE
Još jedan čudan viktorijanski Britanac o kojem morate znati je Augustus de Morgan. Iznio je promatranje transformacije u Booleovoj teoriji skupova, čega svaki SQL programer mora biti svjestan. Ovo je što NE može promijeniti način rada AND i OR. Kratka verzija je da morate biti oprezni kako koristite zagrade u svojim izjavama kako biste izbjegli nenamjerne posljedice. Dakle, i i i ili se također trebaju smatrati važnim logičnim operatorima u SQL-u.
I
I provodi presjeći u teoriji skupova. Ako želite izvući zapise iz baze podataka koji se podudaraju samo s dva zahtjeva, a ne samo jednim od tih složenih kriterija, trebate upotrijebiti AND. Na primjer, možete pokrenuti sjemensku tvrtku, a vaša baza podataka sadrži tablicu koja pohranjuje sva vaša sjemena s njihovim atributima. Kupac se javi i želi samo žute begonije. Dakle, ti bi pretraživao svoju bazu podataka vrsta = “begonija” I boja = “žuta” dobiti pravi katalog sjemena.
ILI
ILI vam daje sve članove dva skupa – to je UNIJA u teoriji skupova. Dakle, u svojoj sjemenskoj bazi podataka ako ste pokrenuli upit: vrsta = “begonija” ILI boja = “žuta”, dobili biste rezultate koji uključuju žute ruže, žutu begoniju, ružičaste begonije i žute narcis. U ovom primjeru, žute se begonije kvalificiraju dva puta. U relacijskoj teoriji treba vratiti samo jedan zapis. Srećom, SQL uključuje kvalifikator jASne, pa ulaskom ODABIR DISTINCT * OD cvijeća GDJE vrsta = “begonija” ILI boja = “žuta”, taj bi se zapis o žutoj begoniji pojavio samo jednom.
NE
Nije lako razumjeti. Isključuje rezultate koje bi proizvela sljedeća izjava: I NE, ILI NE. U praksi gotovo nikad nećete koristiti upitnik “ILI NE”. Ako je vaš kupac za sjeme želio bilo koju drugu boju begonije, osim žute, upotrijebili biste je vrsta = „begonija“, a NE boja = „žuta“ za odabir proizvoda za ponuditi.
Zagrade
Prema De Morganovom zakonu:
„Negacija disjunkcije spoj je negacija; a negacija konjukcije je disjunkcija negacija. “.
Na običnom engleskom jeziku koristite zagrade pažljivo u SQL izjavi kada uključuju i NOT kako biste spriječili da se vaši AND-ovi transformiraju u OR-ove i obrnuto. Uvjeti zagrade zajedno mogu također skratiti kriterije odabira. Na primjer, NE (vrste = „begonija“ I boja = „žuta“) isto je kao NIJE vrsta = „begonija“ ILI NIJE boja = „žuta“.
Vađenje zapisa
Različite SQL implementacije koriste različite sintakse, ali u ovom ćemo vodiču slijediti Oracleov SQL * Plus. Osnovna struktura izbora SQL podataka je:
ODABERI
IZ
SQL es un lenguaje estructurado de consulta. Fue creado específicamente para la gestión y acceso a datos que se encuentran en bases de datos relacionales. El primer proyecto comercial que utilizó SQL fue Oracle, que todavía tiene su lenguaje de consulta SQL * Plus como base de todo su sistema de gestión de bases de datos relacionales (RDMS). Hoy en día, MySQL, SQL Server, SAP y Sybase todos utilizan SQL para acceder a bases de datos. En esta guía, le proporcionaremos la versión estándar de las instrucciones SQL, prestando especial atención a la implementación de Oracle en SQL * Plus. EDITORS CHOICE: Recomendamos las herramientas de gestión de infraestructura de SolarWinds para supervisar todas sus herramientas de Microsoft, incluido SQL Server. Necesita un paquete de herramientas de supervisión que puedan comunicarse entre sí para cubrir todo el contenido que respalda su base de datos relacional.