SQL

Wikipedia, Entziklopedia askea
sql
SQL
SQL
Sql database shortcut icon.png
Jatorria
Sorrera-urtea1974
Ezaugarriak
Programazio paradigmaProgramazio deklaratibo
Media motaapplication/x-sql eta application/sql
Ekoizpena
DiseinatzaileaDonald D. Chamberlin (en) Itzuli
GaratzaileaEstandarizaziorako Nazioarteko Erakundea, Raymond F. Boyce (en) Itzuli eta Donald D. Chamberlin (en) Itzuli

SQL (ingelesez Structured Query Language; gaztelaniaz, lenguaje de consulta estructurada) domeinu espezifikoko lengoaia da, datu-base erlazionalak kudeatzeko, sistemetako informazioa administratzeko eta berreskuratzeko erabiltzen da. Ezaugarri nagusietako bat aljebra maneiatzea da, eta kontsultak egiteko kalkulu erlazionala. Izan ere, datu-baseetako informazioa modu errazean berreskuratzeko eta horietan aldaketak egiteko erabiltzen da,

Jatorriz aljebra erlazionalean eta kalkulu erlazionalean oinarrituta dago, SQL datuak definitzeko lengoaia bat da, ere datuak manipulatzeko lengoaia da eta gainera datuak kontrolatzeko lengoaia da. SQLren irismenaren barruan sartzen dira datuak txertatzea da, kontsultak egitea, eguneratzeak eta ezabatzea, eskemak sortzea eta aldatzea eta datuetarako sarbidea kontrolatzea. SQL ere, batzuetan, adierazpen-lengoaia gisa deskribatzen da, eta elementu prozesalak ere baditu.

SQL-ren ezaugarri orokorrak[aldatu | aldatu iturburu kodea]

SQL datu-baseetan sartzeko lengoaia da, harreman-sistemen malgutasuna eta potentzia ustiatzen ditu, horren ondorioz, eragiketa ugari egiteko aukera ematen digu.

Maila handiko edo prozedura gabeko hizkuntza adierazlea denez, oinarri teoriko sendoari esker eta erregistro-multzoak maneiatzekoa erabilita, kodifikazioan produktibitate handia eta objektuetara orientatzea ahalbidetzen du.


Datuak definitzeko lengoaia: SQLren LDDk komandoak ematen ditu erlazio-eskemak definitzeko, erlazioak ezabatzeko eta erlazio-eskemak aldatzeko.

Datuak manipulatzeko lengoaia interaktiboa: SQLren DMLk kontsulta-lengoaiak barne hartzen ditu, aljebra erlazionalean zein tuplen kalkulu erlazionalean oinarrituta.

Osotasuna: SQLren LDDk datu-basean biltegiratutako datuek bete beharreko osotasun-murrizketak zehazteko komandoak barne hartzen ditu.

Ikuspegiak definitzea: LDDk bistak definitzeko komandoak ditu.

Transakzioen kontrola: SQLk transakzio baten hasiera eta amaiera zehazteko komandoak ditu.

SQL txertatua eta dinamikoa: horrek esan nahi du programazio-lengoaietan SQL jarraibideak sar daitezkeela, hala nola: C++, C, Java, PHP, COBOL, Pascal eta Fortran.

Baimena: LDDk komandoak ditu harremanetarako eta ikustaldietarako sarbide-eskubideak zehazteko.

Datu motak[aldatu | aldatu iturburu kodea]

Hona hemen SQLren oinarrizko datu mota batzuk:

  • Varchar: letraz, zenbakiz eta karaktere bereziz osatutako hitz-katea jasotzen du.
  • INT da SQL Server-en balio osoen datu mota nagusia. Zenbaki osoak zeinuarekin edo zeinurik gabe auki ditzazkegu.
  • Date: egutegiko data bat, urtea (lau zifrakoa), hilabetea eta eguna jasotzen dituena.
  • Time: eguneko ordua ordu minutu segundotan (aurrez zehaztutako balioa 0 da).

Optimizazioa[aldatu | aldatu iturburu kodea]

SQL lengoaia adierazlea da. Hau da, zer nahi den zehazten du, eta ez nola lortu, beraz, sententzia batek ez du exekuzio ordenatu bat jarraitu behar.

Barneko exekuzio ordenatu bat sekuentzia batean eragin larria izan dezake SGBD- an, horregatik beharrezkoa da optimizazio bat egitea ejekuzioa egin aurretik. Askotan, idizeen erabilerak kontsulta-sententzia bizkortzen du, baina datuen eguneratzea moteltzen du. Aplikazioaren erabileraren arabera lehentasuna emango zaio indexatutako sarbideari edo informazioa azkar eguneratzeari. Optimizazioa nabarmen aldatzen da datu-baseko motor bakoitzean, eta faktore askoren mende dago.

Datu-base modernoen sistemek kontsultak optimizatzeko osagai bat dute. SQL kontsulta bat gauzatzeko plan posibleen azterketa zehatza egiten du, eta kontsulta aurrera eramateko eraginkorrena aukeratzen du.

Datuen Definizio Lengoaia (DDL)[aldatu | aldatu iturburu kodea]

Datuak definitzeko lengoaia (ingelesez Data Definition Language edo ddl) datu-baseko objektuen egitura aldatzeaz arduratzen dena da. Datu-basean dauden datuak gordetu, taulak aldatu, ezabatu edo definitzeko aginduak barne hartzen ditu. Oinarrizko lau eragiketa daude: CREATE, ALTER, DROP eta TRUNCATE.

CREATE (Sortu)[aldatu | aldatu iturburu kodea]

Komando honek datu-basearen dauden objektuak sortzeko aukera ematen du, gainera datu-base berriak, taulak, bistak eta biltegiratutako prozedurak sortzeko balio du.

Adibidea(Tabla bar sortu)[aldatu | aldatu iturburu kodea]
CREATE TABLE bezeroak;

ALTER (Taula bati zutabea eranstea)[aldatu | aldatu iturburu kodea]

Komando honek taula edo objektu baten egitura aldatzeko aukera ematen du, ere taula bati eremuak gehitu/kendu dezake, gainera eremu baten mota aldatu, taula bati indizeak gehitu/kendu, trigger bat aldatu, etab.

Adibidea[aldatu | aldatu iturburu kodea]
ALTER TABLE ikasleak ADD urtea INT UNSIGNED;

DROP (Ezabatu)[aldatu | aldatu iturburu kodea]

Komando honek objektu bat ezabatzen du datu-basetik. Taula, bista, aurkibidea, trigger, funtzioa, prozedura edo edozein objektu izan daiteke. ALTER sententziarekin konbina daiteke.

Adibidea ( Taula bat ezabatu)[aldatu | aldatu iturburu kodea]
DROP TABLE ikasleak;

TRUNCATE (Tronkatu)[aldatu | aldatu iturburu kodea]

Komando hau taulei bakarrik aplikatzen zaie, eta zehaztutako taularen eduki osoa ezabatzea da bere funtzioa. DELETE komandoaren gaineko abantaila, taulako eduki guztia ezabatu nahi dugunean, batez ere taula oso handia denean, askoz azkarragoa dela da, . Desabantaila da TRUNCATEk erabiltzeak taularen objetu guztiak erabat ezabatu nahi direnean bakarrik balio duela da, ezin baita WHERE klausula onartu.

Adibidea (Tabla bat erabat ezabatu)[aldatu | aldatu iturburu kodea]
TRUNCATE TABLE bezeroak;

Datuak manipulatzeko lengoaia DML (Data Manipulation Lenguage)[aldatu | aldatu iturburu kodea]

Definizioa[aldatu | aldatu iturburu kodea]

Datuak manipulatzeko lengoaia bat (Data Manipulation Language edo DML ingelesez) datu-baseak kudeatzeko sistemak ematen duen lengoaia bat da, eta erabiltzaileei aukera ematen die datuak kontsultatzeko edo manipulatzeko.

Datuak manipulatzeko lengoaiarik ezagunena SQL da gaur egun, datu-base erlazional batean datuak berreskuratzeko eta manipulatzeko erabiltzen dena.

SELECT (Aukeratu)[aldatu | aldatu iturburu kodea]

SELECT sententziak aukera ematen digu datu-baseko taula batean gordetuta dauden datuak kontsultatzeak

Funtsezko forma[aldatu | aldatu iturburu kodea]
SELECT [{ALL|DISTINCT}]
    <izena_eremua>[, <izena_eremua>...]

FROM {<izena_tabla>|<izena_bista>}[,
    {<izena_tabla>|<izena_bista>}...]

[WHERE <condizioa> [{AND|OR} <condizioa>...]]

[GROUP BY <izena_eremua>[, <izena_eremua>...]]

[HAVING <condizioa> [{AND|OR} <condizioa>...]]

[ORDER BY {<izena_eremua>|<indize_eremua>} [{ASC|DESC}][,
    {<izena_eremua>|<indize_iremua>} [{ASC|DESC}]]];



SELECT

Gako hitza, exekutatu nahi dugun SQL sententzia hautaketa dela adierazten duena.

ALL

Adierazten du balio guztiak hautatu nahi ditugula. Lehenetsitako balioa da, eta ez da ia inoiz zehazten.

DISTINCT

Adieraztu du balio desberdinak bakarrik hautatu nahi ditugula.

FROM

Adieraztu du datuak berreskuratzeko erabili nahi dugun taula (edo taulak). Taula bat baino gehiago badaude, "Kontsulta konbinatua" edo "join" deitzen zaio kontsulta erabili behar da. Kontsulta konbinatuetan, beharrezkoa da konbinazio-baldintza bat aplikatzea WHERE klausula baten bidez.

WHERE

Itzuliko diren datuak balditza bat bete beharko dute, WHERE zehazte duguna zehazki. AND eta OR eragile logikoak onartzen ditu.

GROUP BY

Zehazten du zein talde ematen zaien datuei. Funtzio agregatuekin konbinatuta erabiltzen da beti.

HAVING

baldintza bat zehazten du, eta baldintza hori bete behar da kontsultak datuak itzul ditzan. WHEREren antzeko funtzionamendua du, baina kontsultak itzulitako emaitzei aplikatuta. GROUP BYrekin batera aplikatu behar da beti, eta bertan jasotako eremuei buruzkoa izan behar du baldintzak.

ORDER BY

Emaitzan adierazitako zutabeen arabera ordenatuta aurkezten du. Ordena ASC (goranzko ordena) eta DESC (beheranzko ordena) erabiliz adieraz daiteke. Lehenetsitako balioa ASC da

Adibidea[aldatu | aldatu iturburu kodea]

Autoen taula kontsultatzeko eta matrikula, marka, modeloa, kolorea, kilometro_kopurua, plaza-kopurua eremuak berreskuratzeko, kontsulta hau egin behar dugu. Datuak markaren eta ered

uaren arabera ordenatuta itzuliko dira, goitik beherako zerrendan, txikienetik handienera. FROM gako-hitzak adierazten du datuak Autoak taulatik berreskuratuko direla..

SELECT
    matriulka,
    marka,
    modeloa,
    kolorea,
    kilometro_kopurua,
    plaza_kopurua
FROM
    autoak
ORDER BY
    marka,
    modeloa;

Izartxoaren erabilerak adierazten du kontsultak taulan dauden eremu guztiak itzultzea nahi ditugula, eta datuak markaren eta ereduaren arabera ordenatuta itzuliko dira.

SELECT *
FROM
 autoak
ORDER BY
    marka,
    modeloa;
WHERE klausula (non)[aldatu | aldatu iturburu kodea]

WHERE klausula SELECT sententzia baten emaitza iragazteko aukera ematen digun jarraibidea da. Normalean ez dugu taulan dagoen informazio guztia lortu nahi, momentu horretan erabilgarri izango zaigun informazioa bakarrik nahi dugulako. Where klausulak datuak iragazten ditu kontsultak itzuli aurretik. WHERE klausulan testu mota bat sartu nahi dugunean, balioa komatxo sinpleen artean sartu beharko

dugu.

Gure adibidean, auto jakin bat kontsultatu nahi dugu; horretarako, WHERE klausula bat gehituko dugu. Klausula horrek baldintza bat edo batzuk zehaztu ditzake, SELECT sententzian itzuliko diren datoak baldintza bete beharko dute. Kasu horretan, kontsultak matrikula duen autoaren datuak bakarrik itzuliko ditu, MF-234-ZD matrikula duen autoaren datuak edo FK-938-ZL matrikula soilik.

SELECT
    matrikula,
    marka,
    modeloa,
    colorea,
    kilometro_zenbakia,
    plaza_kopurua
FROM
    autoak
WHERE
    matrikula = 'MF-234-ZD'
    OR matrikula = 'FK-938-ZL';

Hurrengo kontsultak DISTINCT baldintzapekoa erabiltzen du. Autoen taulako marka- eta modelo-eremuek osatutako balio desberdin guztiak itzuliko dizkigu.

SELECT DISTINCT marka, modeloa FROM autoak;
ORDER BY klausula (Ordernar por)[aldatu | aldatu iturburu kodea]

ORDER BY klausulak aukera ematen digu datuak zein ordenatan itzuliko diren zehazteko. Ordena goranzko edo beheranzko moduan zehaztu dezakegu ASC eta DESC gako-hitzen bidez. Ordena zutabean definitutako datu motaren araberakoa da, zenbakizko eremu bat horrela ordenatuko da, eta alfanumeriko bat A-tik Z-ra ordenatuko da, nahiz eta edukia zenbakizkoa izan. Kontsulta egitean zehazten ez bada aurrez zehaztutako balioa ASC izango da.

Adibideak:

SELECT
    matrikula,
    marka,
    modeloa,
    kolorea,
    kilometro_zenbakia,
    plaza_zenbakia
FROM
    autoak
ORDER BY
    marka ASC,
    modeloa DESC;

Adibide honek autoen taulako matrikulak, markak, modeloak, koloreak, kilometroa_zenbakia eta plaza_zenbakia hautatzen ditu, markaren eta modeloaren eremuen arabera ordenatuz, goranzko marka eginez eta beheranzko eredua jarriz.

SELECT
    matrikula,
    marka,
    modeloa,
    kolorea,
    kilometro_zenbakia,
    plaza_zenbakia
FROM
    autoak
ORDER BY 2;


Adibide honek autoen taulako matrikula, marka, modeloa, kolorea, kilometro_zenbakia eta plaza_zenbakia eremu guztiak hautatzen ditu, marka-eremuaren arabera ordenatuz, bigarren lekuan agertzen baita SELECT osatzen duten eremuen zerrendan.

INSERT (Txertatu)[aldatu | aldatu iturburu kodea]

SQLren INSERT sententzia batek datu-base erlazional batean taula bati (eta bakar bati) erregistro bat edo gehiago gehitzen dizkio.

Funtsezko forma[aldatu | aldatu iturburu kodea]
INSERT INTO
    tabla_izena(zutableA, [zutabeB, ...])
VALUES
    ('balorea1', ['balorea2', ...]);

-- baita horrela erabi daiteke:
INSERT INTO tabla_izena VALUES ('balore1', 'balorea2');

Zutabe eta balio kopuruak berdinak izan behar dira. Zutabe bat zehazten ez bada, lehenetsita dagoen balioa esleituko zaio. INSERT sententziak zehaztutako balioek (edo inplizituek) aplikatu beharreko murrizketa guztiak bete beharko dituzte. Sintaxi-errore bat gertatzen bada edo murrizketaren bat urratzen bada, ez da ilara gehituko eta errore bat itzuliko da.

Adibidea[aldatu | aldatu iturburu kodea]
INSERT INTO telefono_agenda (izena, zenbakia)
VALUES ('Roberto Jeldrez', 4886850);

Taularen datu guztiak definitzen ditugunean, sentzia motza erabili daiteke.

INSERT INTO tabla_izena VALUES ('balore1', ['balore2', ...]);

Adibidea jakinda 'izena' eta 'zenbakia' zutabe bakarrak direla telefono_agenda tablan.

INSERT INTO telefono_agenda
VALUES ('Johnny Aguilar', 080473968);

UPDATE (Eguneratu)[aldatu | aldatu iturburu kodea]

SQLren UPDATE sententzia bat, taula batean dauden erregistro multzo baten balioak aldatzeko erabiltzen da.

Adibidea[aldatu | aldatu iturburu kodea]
UPDATE My_table SET field1 = 'updated value' WHERE field2 = 'N';

DELETE (ezabatu)[aldatu | aldatu iturburu kodea]

SQLren DELETE sententzia batek taula batean dauden erregistro bat edo gehiago ezabatzen ditu.

Oinarrizko forma[aldatu | aldatu iturburu kodea]

DELETE FROM WHERE taula_zutabea1 = 'Balorea1'
Adibidea[aldatu | aldatu iturburu kodea]
DELETE FROM nire_tabla WHERE zutabea2 = 'N';

Datu baseak kudeatzeko sistemak[aldatu | aldatu iturburu kodea]

SQL datu-baseak kudeatzeko sistema erabilienak, ordena alfabetikoan, honako hauek dira:

  • DB2
  • Firebird
  • HSQL
  • Informix
  • InterBase
  • MariaDB
  • Microsoft SQL Server
  • MySQL
  • Oracle
  • PostgreSQL
  • PervasiveSQL
  • SQLite
  • Sybase ASE

Erreferentziak[aldatu | aldatu iturburu kodea]

  1. Paul, Ryan (24 de octubre de 2005). «A guided tour of the Microsoft Command Shell»[1]. Ars Technica (en inglés). Consultado el 4 de agosto de 2020.
  2. ↑ Morteo, Bocalandro, Francisco, Nicolás (2004). Un enfoque práctico de SQL. Ediciones Cooperativas. ISBN 987-1076-61-4.
  3. ↑ EF Codd; A relational model of data for large shared data banks. Comm. ACM, 13 (1970), pp. 377-387.
  4. Eisenberg et al.: SQL:2003 Has Been Published.
  5. Aprobación de SQL 2008.
  6. ↑ Chapple, Mike. «SQL Fundamentals». En About.com, ed. Databases. Consultado el 17 de octubre de 2015.
  7. ↑ Saltar a:a b Rockoff, Larry (2011). Course Technology/Cengage Learning, ed. The language of SQL.
  8. ↑ Morteo, Bocalandro., Francisco, Nicolás (2004). Un enfoque práctico de SQL. Ediciones cooperativas. ISBN 987-1076-61-4.
  9. «About PostgreSQL». PostgreSQL 9.1 official website. PostgreSQL Global Development Group. 2012. Consultado el 8 de junio de 2016. «PostgreSQL prides itself in standards compliance. Its SQL implementation strongly conforms to the ANSI-SQL:2008 standard».
  10. «Basic Elements of Oracle SQL: Data Types». Oracle Database SQL Language Reference 11g Release 2 (11.2). Oracle Database Documentation Library. Redwood City, CA: Oracle USA, Inc. Consultado el 8 de junio de 2016.

Kanpo estekak[aldatu | aldatu iturburu kodea]

SQL lenguaia


Informatika Artikulu hau informatikari buruzko zirriborroa da. Wikipedia lagun dezakezu edukia osatuz.
  1. (Ingelesez) Paul, Ryan. (2005-10-24). «A guided tour of the Microsoft Command Shell» Ars Technica (Noiz kontsultatua: 2021-10-12).