கட்டமைப்புள்ள வினவு மொழி


எஸ்.கியூ.எல் (கட்டமைப்பு வினவல் மொழி) (ஒலிப்பு: /ˌɛs.kjuːˈɛl/ ES-kyoo-EL )[1][2] என்பது தொடர்புடைய தரவுத்தள மேலாண்மை அமைப்புகளில் (RDBMS) தரவை நிர்வகிக்க வடிவமைக்கப்பட்ட தரவுத்தள கணினி மொழி ஆகும். உண்மையில் இது தொடர்புடைய இயற்கணிதம் அடிப்படையிலானது. தரவு வினவல் மற்றும் புதுப்பிப்பு, ஸ்கீமா உருவாக்கம், மாற்றியமைத்தல் மற்றும் தரவு அணுகல் கட்டுப்பாடு உள்ளிட்டவை அதன் மையமாகும். எஸ்.கியூ.எல் என்பது எட்கர் எஃப். காட்டின் தாக்கத்தில் 1970 ஆம் ஆண்டு அறிக்கையில் அவரின் தொடர்பு மாதிரிக்கான முதல் மொழிகளில் ஒன்றாகும். "மிகப்பெரிய அளவில் பகிரப்பட்ட தரவு வங்கிகளுக்கான தரவின் ஒரு தொடர்பு மாதிரியான" இது, தொடர்பு தரவுத்தளங்களுக்காக பெரும்பாலும் பரவலாக பயன்படுத்தப்பட்ட மொழியாக உள்ளது.

SQL
நிரலாக்கக் கருத்தோட்டம்:Multi-paradigm
தோன்றிய ஆண்டு:1974
வடிவமைப்பாளர்:Donald D. Chamberlin and Raymond F. Boyce
வளர்த்தெடுப்பாளர்:ஐபிஎம்
அண்மை வெளியீட்டுப் பதிப்பு:SQL:2008
அண்மை வெளியீட்டு நாள்:2008
இயல்பு முறை:Static, strong
முதன்மைப் பயனாக்கங்கள்:Many
மொழி வழக்குகள்:SQL-86, SQL-89, SQL-92, SQL:1999, SQL:2003, SQL:2008
பிறமொழித்தாக்கங்கள்:Datalog
இம்மொழித்தாக்கங்கள்:CQL, LINQ, Windows PowerShell
இயக்குதளம்:Cross-platform

வரலாறு தொகு

டொனால்டு டி. சேம்பர்லின் மற்றும் ரேமண்ட் எஃப். பாய்ஸ் ஆகியோரால் ஐபிஎம் நிறுவனம் மூலமாக 1970களின் தொடக்கத்தில் எஸ்.கியூ.எல் உருவாக்கப்பட்டது. இந்தப் பதிப்பானது தொடக்கத்தில் சீக்வெல் என்று அழைக்கப்பட்டது. இது IBM நிறுவனத்தின் அசல் தொடர்பு தரவுத்தள தயாரிப்பான சிஸ்டம் ஆரில் சேமிக்கப்பட்ட தரவை கையாளவும் பெறவும் வடிவமைக்கப்பட்டது.

1970களில் IBM சேன் ஜோஸ் ரிசர்ஜ் லேபரட்டரியில் ஒரு குழு சிஸ்டம் ஆர் என்ற தொடர்புடைய தரவுத்தள மேலாண்மை அமைப்பை உருவாக்கியது. IBMஐச் சேர்ந்த டொனால்டு டி. சேம்பர்லின், ரேமண்ட் எஃப் பாய்ஸ் இருவரும் பின்னர் சிஸ்டர் ஆரில் சேமிக்கப்பட்டுள்ள தரவை நிர்வகிக்க கட்டமைக்கப்பட்ட ஆங்கில வினவல் மொழியை (SEQUEL அல்லது SEQL) உருவாக்கினர்.[3] சீக்வெல் (SEQUEL) என்ற சுருக்கப் பெயரானது எஸ்.கியூ.எல் என்று பின்னர் மாற்றப்பட்டது. ஏனெனில் "சீக்வெல்" என்பது இங்கிலாந்தைச் சார்ந்த ஹாவ்கர் சிட்டேலே விமான நிறுவனத்தின் வர்த்தகச் சின்னம் ஆகும்.[4]

முதல் தொடர்புடைய தரவுத்தள மேலாண்மை அமைப்பு (RDBMS) RDMS ஆகும். அது 1970களின் ஆரம்பத்தில் MIT இல் உருவாக்கப்பட்டது. அது 1974 ஆம் ஆண்டில் யூ.சி. பெர்க்லேயில் உருவாக்கப்பட்ட இன்கெரெஸ் (Ingres) மூலமாக விரைவில் பயன்படுத்தப்பட்டது. இன்கெரெஸானது QUEL என்ற வினவல் மொழியால் செயலாக்கப்பட்டது. பின்னர் QUEL இன் இடத்தை எஸ்.கியூ.எல் நிரப்பியது.[4]

1970களின் இறுதியில் ரிலேஷனல் சாஃப்ட்வேர், இங்க். (இப்பொழுது ஆரக்கிள் கார்ப்பரேஷன்) நிறுவனம் கோட், சேம்பர்லீன் மற்றும் பாய்ஸ் ஆகியோரால் விவரிக்கப்பட்ட கருதுகோள்களின் சாத்தியங்களைக் கண்டது. மேலும் அவர்களின் சொந்த எஸ்.கியூ.எல்-அடிப்படையான RDBMSஐ அமெரிக்க கப்பல்படை, செண்ட்ரல் இண்டிலிஜென்ஸ் ஏஜென்சி மற்றும் பிற அமெரிக்க அரசாங்க நிறுவனங்களுக்கு விற்கின்ற நோக்கங்களில் உருவாக்கியது. 1979 ஆம் ஆண்டின் கோடைகாலத்தில், ரிலேஷனல் சாஃப்ட்வேர், இங்க். நிறுவனம் முதல் வணிகரீதியில் கிடைக்கின்ற எஸ்.கியூ.எல்லின் செயலாக்கத்தை வேக்ஸ் கணினிகளுக்காக ஆரக்கில் வீ2 (பதிப்பு2) ஐ அறிமுகப்படுத்தியது. ஆரக்கில் வீ2 சந்தைப்படுத்தப்பட்ட சில வாரங்களில் IBM இன் வெளியீடான system/38 RDBMSஐ வீழ்த்தியது.

வாடிக்கையாளர் சோதனைத் தளங்களில் அமைப்பின் பயன்படும் தன்மை மற்றும் நடைமுறை சாத்தியம் ஆகியவற்றைக் கண்டறிய எஸ்.கியூ.எல்லை சோதனை செய்த பின்னர், IBM நிறுவனம் system/38, SQL/DS மற்றும் DB2 உள்ளிட்ட அவர்களின் system R மாதிரியின் அடிப்படையிலான வணிக தயாரிப்புகளை உருவாக்கத் தொடங்கியது. இவை முறையே 1979, 1981, மற்றும் 1983 ஆகிய ஆண்டுகளில் வணிக ரீதியில் கிடைத்தன.[5]

விற்பனையாளர்களிடையே பிளாட்பார்ம் மாற்ற கையாளல் குறைபாட்டை அறிதல், தவற விடப்பட்ட தரவை (காண்க Null (SQL) ) சரியற்ற முறையில் கையாளுதல், தேவையின்றி சிக்கலாக இருத்தல், எப்போதாவது ஏற்படும் தெளிவற்ற மொழி இலக்கணம் மற்றும் பொருள்கள் உள்ளிட்டவை எஸ்.கியூ.எல்லின் பொதுவான விமர்சனங்கள் ஆகும். இது தொடர்புடைய இயற்கணிதம் போன்ற பல இயல்பு மொழிகளின் கடினத்தன்மையில் குறைபாட்டையும் கொண்டிருக்கின்றது.

மொழி கூறுகள் தொகு

 
இந்த விளக்கப்படமானது தனித்த வாக்கியத்தை உருவாக்கும் பல எஸ்.கியூ.எல் மொழி உறுப்புகளைக் காண்பிக்கிறது.

எஸ்.கியூ.எல் மொழியானது பல்வேறு மொழிக் கூறுகளாகப் பிரிக்கப்பட்டுள்ளது, அவை பின்வருமாறு:

  • பிரிவுகள், வாக்கியங்களின் கூறுகளின் அங்கம் மற்றும் வினவல்கள் போன்ற சில நிகழ்வுகளில் உள்ளன.[6]
  • கோவைகள், இவை தரவின் நெடுவரிசைகள் மற்றும் வரிசைகள் ஆகியவற்றைக் கொண்ட அளவீட்டு மதிப்புகளை அல்லது அட்டவணைகளை உருவாக்க முடியும்.
  • பயனிலைகள், இவை எஸ்.கியூ.எல்லிற்கு மூன்று மதிப்பிடப்பட்ட தர்க்கம் (3VL) பூலியன் உண்மை மதிப்புகளை மதிப்பீடு செய்யமுடிந்த நிபந்தனைகளைக் குறிப்பிடுகின்றன. மேலும் இவை வாக்கியங்கள் அல்லது வினவல்களின் விளைவுகளைக் கட்டுப்படுத்த அல்லது நிரல் ஓட்டத்தை மாற்ற பயன்படுகின்றன.
  • வினவல்கள், இவை குறிப்பிட்ட திட்ட அளவைகள் அடிப்படையிலான தரவைப் பெறுகின்றன.
  • வாக்கியங்கள், இவை ஸ்கீமாக்கள் மற்றும் தரவு ஆகியவற்றில் ஒரேமாதிரியான விளைவைக் கொண்டிருக்கலாம் அல்லது இவை பரிமாற்றங்கள், நிரல் ஓட்டம், இணைப்புகள், அமர்வுகள் அல்லது அறுதியிடல்களை கட்டுப்படுத்தலாம்.
    • எஸ்.கியூ.எல் வாக்கியங்கள் அரைப்புள்ளியை (";") வாக்கிய முற்றாகவும் கொண்டிருக்கின்றன. இருப்பினும் இது ஒவ்வொரு தளத்திற்கும் அவசியமில்லை. இது எஸ்.கியூ.எல் இலக்கணத்தின் தரநிலைப் பகுதியாக வரையறுக்கப்படுகின்றது.
  • முக்கியமற்ற இடைவெளியானது பொதுவாக எஸ்.கியூ.எல் வாக்கியங்கள் மற்றும் வினவல்கள் ஆகியவற்றில் தவிர்க்கப்படுகின்றது. இது எஸ்.கியூ.எல் குறியீட்டு வடிவமைப்பை படிக்கத்தக்கவாறு எளிதாக்குகின்றது.

வினவல்கள் தொகு

வினவல் என்பது எஸ்.கியூ.எல்லில் மிகவும் பொதுவான செயல்பாடு ஆகும். இது அறிவித்தல் SELECT வாக்கியத்துடன் நிகழ்த்தப்படுகின்றது. SELECT வாக்கியமானது தரவை ஒன்று அல்லது அதற்கு மேற்பட்ட அட்டவணைகள் அல்லது கோவைகளில் இருந்து பெறுகின்றது. தரநிலையான SELECT கூற்றுக்கள் தரவுத்தளத்தில் ஒரே மாதிரியான விளைவுகளைக் கொண்டிருப்பதில்லை. SELECT இன் சில தரநிலையற்ற செயலாக்கங்கள் சில தரவுத்தளங்களில் காணப்படும் SELECT INTO தொடரியல் போன்று ஒரே மாதிரியான விளைவுகளைக் கொண்டிருக்கலாம்.[7]

வினவல்கள் பயனரை தேவையான தரவை விவரிக்க அனுமதிக்கின்றது. தரவுத்தள மேலாண்மை அமைப்பை(DBMS) திட்டமிடல், ஏற்புடையதாக்கல் மற்றும் அது தேர்ந்தெடுக்கின்ற முடிவை வருவிக்கத் தேவையான இயற்பியல் ரீதியான செயல்பாடுகளை நிகழ்த்த விடுகின்றது.

ஒரு வினவலானது SELECT குறிச்சொல்லை உடனடியாகப் பின்பற்றி வருகின்ற இறுதி முடிவில் சேர்க்கப்படக்கூடிய நெடுவரிசைகளின் பட்டியலைக் கொண்டுள்ளது. ஒரு நட்சத்திரக் குறியானது ("*") அந்த வினவலானது வினவப்பட்ட அட்டவணைகளின் அனைத்து நெடுவரிசைகளையும் கொடுக்க வேண்டும் என்பதைக் குறிக்கவும் பயன்படுத்தப்படலாம். SELECT என்பது எஸ்.கியூ.எல்லில் விருப்பக் குறிச்சொற்கள் மற்றும் பிரிவுகளைக் கொண்ட மிகவும் சிக்கலான கூற்றாகும், அது பின்வருவனவற்றை உள்ளடக்குகின்றது:

  • FROM பிரிவானது எந்த அட்டவணை(களில்) இருந்து தரவு பெறப்பட இருக்கின்றது என்பதைக் குறிக்கின்றது. FROM பிரிவானது இணைக்கப்படும் அட்டவணைகளுக்கான விதிகளைக் குறிப்பிட விருப்ப JOIN துணைப்பிரிவுகளை சேர்க்க முடியும்.
  • WHERE பிரிவானது ஒரு ஒப்பீட்டு நிலையை கொண்டிருக்கின்றது. இது வினவலால் வரிசைகள் அளிக்கப்படுவதைக் கட்டுப்படுத்துகின்றது. WHERE பிரிவானது உண்மைக்கு மதிப்பிடப்படாத ஒப்பீட்டு நிலைக்கான முடிவுத் தொகுப்பிலிருந்து அனைத்து வரிசைகளையும் நீக்குகின்றது.
  • GROUP BY பிரிவானது சிறிய வரிசைகளில் தொகுப்பில் பொதுவான மதிப்புகளைக் கொண்ட வரிசைகளைக் காண்பிக்கப் பயன்படுகின்றது. GROUP BY என்பது பெரும்பாலும் எஸ்.கியூ.எல் ஒருங்கிணைப்பு செயல்பாடுகளுடன் சேர்க்கையில் பயன்படுகின்றது அல்லது முடிவுத் தொகுப்பில் இருந்து பிரதி வரிசைகளை நீக்கப் பயன்படுகின்றது. WHERE பிரிவானது GROUP BY பிரிவுக்கு முன்னர் பொருத்தப்படுகின்றது.
  • HAVING பிரிவானது GROUP BY பிரிவிலிருந்து வெளிவரும் முடிவு வரிசைகளை வடிகட்டப் பயன்படுத்தும் நிலையைக் கொண்டிருக்கின்றது. ஏனெனில் இது GROUP BY பிரிவின் முடிவுகளில் செயல்படுகின்றது. மொத்த செயல்பாடுகளை HAVING பிரிவு நிலையில் பயன்படுத்த முடியும்.
  • ORDER BY பிரிவானது நெடுவரிசைகள் முடிவான தரவை வரிசைப்படுத்தப் பயன்படுகின்றது மற்றும் எந்தத் திசையில் அவை வரிசைப்படுத்தப்பட வேண்டும் (விருப்பங்களாக ஏறுவரிசை அல்லது இறங்குவரிசை உள்ளன) என்பதை அடையாளம் காணுகின்றது. ORDER BY பிரிவு இல்லாமல் எஸ்.கியூ.எல் வினவல் மூலமாக அளிக்கப்பட்ட வரிசைகளின் வரிசைப்படுத்தலானது வரையறுக்க முடியாததாக உள்ளது.

பின்வருவது விலையுயர்ந்த நூல்களின் பட்டியலை அளிக்கின்ற SELECT வினவலின் உதாரணம் ஆகும். வினவலானது price நெடுவரிசையானது 100.00 க்கும் அதிகமான மதிப்பைக் கொண்டுள்ள Book அட்டவணையிலிருந்து அனைத்து வரிசைகளையும் எடுக்கின்றது. முடிவானது title இன் படி ஏறுவரிசையில் வரிசைப்படுத்தப்பட்டுள்ளது. select list இல் நட்சத்திரக் குறியீடானது (*) Book அட்டவணையின் அனைத்து நெடுவரிசைகளையும் முடிவுத் தொகுப்பில் சேர்க்கப்பட வேண்டும் என்பதைக் குறிக்கின்றது.

SELECT * 
 FROM Book
 WHERE price > 100.00
 ORDER BY title;

கீழேயுள்ள உதாரணமானது பல்வேறு அட்டவணைகள், குழுப்படுத்துதல் மற்றும் ஒருங்கிணைத்தல் ஆகியவற்றின் வினவலை நூல்களின் பட்டியல் மற்றும் ஒவ்வொரு நூலுடன் தொடர்புடைய ஆசிரியர்களின் எண்ணிக்கை ஆகியவற்றை அளிப்பதன் மூலமாக விளக்குகின்றது.

SELECT Book.title,
 count(*) AS Authors
 FROM Book
 JOIN Book_author ON Book.isbn = Book_author.isbn
 GROUP BY Book.title;

உதாரண வெளியீடானது பின்வருவனவற்றை ஒத்திருக்கலாம்:

Title Authors
---------------------- -------
SQL Examples and Guide 4
The Joy of SQL 1
An Introduction to SQL 2
Pitfalls of SQL 1

நிபந்தனையின் முன்னர் isbn மட்டுமே இரண்டு அட்டவணைகளின் பொதுவான நெடுவரிசைப் பெயராகும். மேலும் title என்ற நெடுவரிசைப் பெயர் Books அட்டவணையில் மட்டுமே உள்ளது, மேலே உள்ள வினவலை பின்வரும் வடிவில் எழுதலாம்:

SELECT title,
 count(*) AS Authors
 FROM Book 
 NATURAL JOIN Book_author 
 GROUP BY title;

இருப்பினும் பல விற்பனையாளர்கள் ஒன்று இந்த அணுகுமுறையை ஆதரிப்பதில்லை அல்லது நெடுவரிசை பெயர் மாற்றங்களைக் கோருகின்றனர்.

எஸ்.கியூ.எல் சேமிக்கப்பட்ட மதிப்புகளில் கணிக்கப்படும் மதிப்புகளுக்கான செயற்குறிகள் மற்றும் செயல்பாடுகளைக் கொண்டுள்ளது. எஸ்.கியூ.எல் ஆனது வெளிப்படும் தரவிற்கு select list இல் கோவைகளின் பயன்பாட்டை அனுமதிக்கின்றது. பின்வரும் உதாரணத்தில் 100.00க்கும் அதிகமான விலையுடைய நூல்களின் பட்டியலை அளிப்பதுடன் கூடுதலாக sales_tax நெடுவரிசை விற்பனை வரி மதிப்பானது விலையில் 6% கணக்கிடப்பட்டுள்ளது.

SELECT isbn,
 title,
 price, 
 price * 0.06 AS sales_tax
 FROM Book
 WHERE price > 100.00
 ORDER BY title;

Null மற்றும் மூன்று மதிப்பு தர்க்கம் (3VL) தொகு

Null என்ற கருத்தானது தொடர்பு மாதிரியில் விடுபட்ட தகவலைக் கையாள எஸ்.கியூ.எல்லில் அறிமுகப்படுத்தப்பட்டது. Null (அல்லது தெரியவில்லை) என்பதன் அறிமுகம் மூன்று மதிப்பு தர்க்கத்தின் அடிப்படையான சரி மற்றும் தவறுடன் இணைந்துள்ளது. Null என்பது எந்த மதிப்பையும் கொண்டிருக்கவில்லை (மேலும் இது எந்த தரவு களத்தின் உறுப்பினராகவும் இல்லை) ஆனால் மாறாக பிளேஸ்ஹோல்டர் அல்லது விடுபட்ட தகவலுக்கான "குறியீடாக" உள்ளது. எனவே Null உடனான ஒப்பீடுகள் எப்போதும் சரி அல்லது தவறில் முடியாது. ஆனால் எப்போதும் மூன்றாவது தர்க்க முடிவான தெரியவில்லையில் முடியும்.[8]

எஸ்.கியூ.எல் விடுபட்ட தகவலைக் கையாள Nullஐ பயன்படுத்துகின்றது. அது மூன்றாவது மதிப்பு தர்க்கத்தை (3VL) ஆதரிக்கின்றது. மேலும் விதிகள் கீழே காணப்படும் எஸ்.கியூ.எல் மூன்றாவது மதிப்பு தர்க்கத்தை (3VL) ஆளுகின்றன (p மற்றும் q தர்க்க நிலைகளை குறிக்கின்றன).[9] NULL என்ற வார்த்தையானது எஸ்.கியூ.எல் ஒதுக்கப்பட்ட குறிச்சொல்லாகவும் உள்ளது. இது Null சிறப்புக் குறியீட்டை அடையாளம் காணப் பயன்படுகின்றது.

கூடுதலாக எஸ்.கியூ.எல் இயக்கிகளானது Null உடன் எதையும் ஒப்பிடுகையில் தெரியவில்லை என்பதை அளிப்பதால் எஸ்.கியூ.எல் இரண்டு Null-குறிப்பிட்ட ஒப்பீடு நிலைகளை வழங்குகின்றது: IS NULL மற்றும் IS NOT NULL சோதனையில் தரவானது Null ஆக உள்ளதா அல்லது இல்லையா என்பதைக் கூறுகின்றது.[10]

எஸ்.கியூ.எல்லில் WHERE பிரிவானது சரி மதிப்பை அளிப்பவைக்கு மட்டுமே முடிவுகளை அளிக்கின்றது என்பதை நினைவில் கொள்க. அதாவது அது தவறு மதிப்புகளை உடைய முடிவுகளைத் தவிர்க்கின்றது. ஆனால் அவை தெரியவில்லை என்ற மதிப்பைக் கொண்டிருக்கின்றது.

valign="top"
p AND q ப்பி
சரி தவறு தெரியவில்லை
சரி சரி தவறு தெரியவில்லை
தவறு தவறு தவறு தவறு
தெரியவில்லை தெரியவில்லை தவறு தெரியவில்லை
valign="top"
p OR q p
சரி தவறு தெரியவில்லை
சரி சரி சரி சரி
தவறு சரி தவறு தெரியவில்லை
தெரியவில்லை சரி தெரியவில்லை தெரியவில்லை
valign="top"
p NOT p
சரி தவறு
தவறு சரி
தெரியவில்லை தெரியவில்லை
valign="top"
p = q p
சரி தவறு தெரியவில்லை
சரி சரி தவறு தெரியவில்லை
தவறு தவறு சரி தெரியவில்லை
தெரியவில்லை தெரியவில்லை தெரியவில்லை தெரியவில்லை

உலகளாவிய அளவீடு எஸ்.கியூ.எல் மூலமாக வெளிப்படையாக ஆதரிப்படவில்லை. மேலும் இல்லாததாக்கப்பட்ட புறமெய்மை நிலை அளவீடாக கண்டிப்பாக கணக்கிடப்பட வேண்டும்.[11][12][13]

"<row value expression> IS DISTINCT FROM <row value expression>" என்பது இரண்டு ஏற்பிகளும் சமமாக இருந்தால் அல்லது இரண்டும் NULL ஆக இருந்தால் சரியை வழங்குகின்ற ஒப்பீட்டு இயக்கிகளை இடையமைக்கப்பட்டுள்ளது. அதே போன்று IS NOT DISTINCT FROM என்பது "NOT (<row value expression> IS DISTINCT FROM <row value expression>") ஆக வரையறுக்கப்படுகின்றது.

தரவு கையாளல் தொகு

தரவு கையாளல் மொழி (DML) என்பது எஸ்.கியூ.எல்லின் ஒரு துணைத் தொகுப்பாகும். இது தரவைச் சேர்க்க, புதுப்பிக்க மற்றும் நீக்கப் பயன்படுத்தப்படும்:

INSERT INTO My_table 
 (field1, field2, field3) 
 VALUES 
 ('test', 'N', NULL);
  • UPDATE, இருக்கின்ற அட்டவணை வரிசைகளின் தொகுப்பை மாற்றுகிறது, எ.கா.,:
UPDATE My_table 
 SET field1 = 'updated value' 
 WHERE field2 = 'N';
  • DELETE, அட்டவணையிலிருந்து இருக்கின்ற வரிசைகளை நீக்குகிறது, எ.கா.,:
DELETE FROM My_table 
 WHERE field2 = 'N';
  • TRUNCATE ஆனது அட்டவணையிலுள்ள அனைத்து தரவையும் அதி வேகமான வழியில் நீக்குகிறது. இது பொதுவாக அதைத் தொடர்ந்துவரும் COMMIT செயல்பாட்டால் குறிக்கப்படுகிறது.
  • MERGE, பல அட்டவணைகளிலுள்ள தரவுகளை ஒன்றுசேர்க்கப் பயன்படுகிறது. இது INSERT மற்றும் UPDATE கூறுகளை ஒன்றிணைக்கிறது. இது எஸ்.கியூ.எல்:2003 தரத்தில் வரையறுக்கப்படுகிறது. அதற்கு முன்னர் சில தரவுத்தளங்கள் இதேபோன்ற செயல்திறனை வேறுபட்ட தொடரியல் வழியாக வழங்கின. சில வேளைகளில் இது "upsert" என அழைக்கப்பட்டது.

பரிமாற்ற கட்டுப்பாடுகள் தொகு

பரிமாற்றங்கள் இருந்தால் DML செயல்பாடுகளை ஒழுங்குபடுத்தும்:

  • START TRANSACTION (அல்லது BEGIN WORK அல்லது BEGIN TRANSACTION, எஸ்.கியூ.எல் கிளைமொழியைப் பொறுத்தது) ஆனது முழுவதுமாகப் பூர்த்திசெய்யப்பட்ட அல்லது ஒன்றுமே செய்யப்படாத தரவுத்தள பரிமாற்றத்தின் தொடக்கத்தைக் குறிக்கிறது.
  • SAVE TRANSACTION (அல்லது SAVEPOINT ) ஆனது நடப்பு நிலையில் தரவுத்தளத்தின் நிலையை பரிமாற்றத்தில் சேமிக்கிறது.
CREATE TABLE tbl_1(id int);
 INSERT into tbl_1(id) value(1);
 INSERT into tbl_1(id) value(2);
COMMIT;
 UPDATE tbl_1 SET id=200 WHERE id=1;
SAVEPOINT id-1upd;
 UPDATE tbl_1 SET id=1000 WHERE id=2;
ROLLBACK to id-1upd;
 SELECT id from tbl_1;
  • COMMIT ஆனது அனைத்து தரவு மாற்றங்களையும் பரிமாற்றத்தில் நிரந்தரமாக செய்யும்படி செய்கிறது.
  • ROLLBACK ஆனது கடைசியான COMMIT அல்லது ROLLBACK க்குப் பின்னர் செய்யப்படும் அனைத்து தரவு மாற்றங்களையும் முடக்கும்படி செய்யும். அந்த மாற்றங்களுக்கு முன்னர் இருந்தது போலவே தரவு நிலையைத் தொடர்ந்து அனுமதிக்கிறது.

COMMIT வாக்கியம் முடிந்ததும் பரிமாற்றத்தின் மாற்றங்களை மீண்டும் திரும்பப் பெறமுடியாது.

COMMIT மற்றும் ROLLBACK ஆகியவை நடப்பு பரிமாற்றத்தை நிறுத்தி தரவுப் பூட்டுக்களை விடுவிக்கின்றன. START TRANSACTION அல்லது இதேபோன்ற வாக்கியம் ஒன்று இல்லாத நிலையில் SQL இன் பொருள்கள் செயலாக்கத்தைப் பொறுத்தன. எடுத்துக்காட்டு: அங்கீகாரம் பெற்ற வங்கி நிதி இடமாற்ற பரிமாற்றம்.

START TRANSACTION;
 UPDATE Account SET amount=amount-200 WHERE account_number=1234;
 UPDATE Account SET amount=amount+200 WHERE account_number=2345;
IF ERRORS=0 COMMIT;
IF ERRORS<>0 ROLLBACK;

தரவு வரையறை தொகு

தரவு வரையறை மொழியானது (DDL) அட்டவணை மற்றும் அடைவு வடிவமைப்பை நிர்வகிக்கிறது. DDL இன் பெரும்பாலான அடிப்படை உருப்படிகளாவன, CREATE, ALTER, RENAME, DROP மற்றும் TRUNCATE வாக்கியங்களாகும்:

  • CREATE ஆனது தரவுத்தளத்தில் ஒரு குறிக்கோளை (எடுத்துக்காட்டாக, ஒரு அட்டவணை) உருவாக்குகிறது.
  • DROP ஆனது தரவுத்தளத்திலுள்ள ஒரு குறிக்கோளை மீட்டெடுக்க முடியாதவகையில் நீக்குகிறது.
  • ALTER என்பது முன்பே உள்ள குறிக்கோளின் கட்டமைப்பைப் பல வழிகளில் மாற்றியமைக்கிறது. எடுத்துக்காட்டாக, ஏற்கனவே அட்டவணையில் ஒரு நெடுவரிசையைச் சேர்த்தல்.

எடுத்துக்காட்டு:

CREATE TABLE My_table
(
 my_field1 INT,
 my_field2 VARCHAR(50),
 my_field3 DATE NOT NULL,
 PRIMARY KEY (my_field1, my_field2) 
);

தரவு வகைகள் தொகு

எஸ்.கியூ.எல் அட்டவணையிலுள்ள ஒவ்வொரு நெடுவரிசையும் அந்த நெடுவரிசை கொண்டிருக்கக்கூடிய வகை(களை)யை விபரிக்கிறது. ANSI எஸ்.கியூ.எல்லில் பின்வரும் தரவு வகைகள் உள்ளடங்கும்.[14]

எழுத்துக்குறி சரங்கள் தொகு

  • CHARACTER(n) அல்லது CHAR(n) — நிலையான-அகலம் n-எழுத்துக்குறி சரம், தேவைக்கு ஏற்ப இடைவெளிகள் சேர்க்கப்படும்
  • CHARACTER VARYING(n) அல்லது VARCHAR(n) — அதிகபட்ச அளவாக n எழுத்துக்குறிகளைக் கொண்ட மாறுகின்ற-அகலமுடைய சரம்
  • NATIONAL CHARACTER(n) அல்லது NCHAR(n) — சர்வதேச எழுத்துக்குறி தொகுப்பை ஆதரிக்கும் நிலையான அகலமுடைய சரம்
  • NATIONAL CHARACTER VARYING(n) அல்லது NVARCHAR(n) — மாறுகின்ற-அகலமுடைய NCHAR சரம்

பிட் சரங்கள் தொகு

  • BIT(n)n பிட்களின் அணிவரிசை
  • BIT VARYING(n)n பிட்கள் வரையான அணிவரிசை

எண்கள் தொகு

  • INTEGER மற்றும் SMALLINT
  • FLOAT, REAL மற்றும் DOUBLE PRECISION
  • NUMERIC(துல்லியம், அளவு) அல்லது DECIMAL(துல்லியம், அளவு)

எண்களை அல்லது தேதிகளை முழு எண்ணாக்குவதற்கான செயல்பாட்டை எஸ்.கியூ.எல் வழங்குகிறது. இது TRUNC என்றும் (DB2, போஸ்ட்கெரேஎஸ்.கியூ.எல், ஆரக்கிள் மற்றும் மைஎஸ்.கியூ.எல் ஆகியவற்றில்) அல்லது ROUND என்றும் (சைபேஸ், ஆரக்கிள் மற்றும் மைக்ரோசாஃப்ட் எஸ்.கியூ.எல் சர்வர் ஆகியவற்றில்) அழைக்கப்படும்[15]

தேதியும் நேரமும் தொகு

  • DATE
  • TIME
  • TIMESTAMP
  • INTERVAL

தேதிக் கட்டுப்பாடு தொகு

பயனர்களும் குழுக்களும் தரவுகளை அணுகுவதையும் கையாள்வதையும் தேதிக் கட்டுப்பாட்டு மொழி (DCL) அங்கீகரிக்கிறது. இதன் முக்கியமான இரு பிரதான வாக்கியங்களாவன:

  • GRANT ஆனது ஒரு பயனர் அல்லது அதிக பயனர்கள் ஒரு குறிக்கோளின் மீது செயல்பாட்டை அல்லது செயல்பாட்டுத் தொகுதியைச் செய்ய அங்கீகரிக்கிறது.
  • REVOKE ஆனது கிராண்டை நீக்குகிறது. இது இயல்பான கிராண்டாக இருக்கக்கூடும்.

எடுத்துக்காட்டு:

GRANT SELECT, UPDATE 
 ON My_table 
 TO some_user, another_user;

REVOKE SELECT, UPDATE 
 ON My_table 
 FROM some_user, another_user;

செயல்முறை நீட்டிப்புகள் தொகு

எஸ்.கியூ.எல் ஆனது பின்வரும் தனிப்பட்ட நோக்கத்துக்கென வடிவமைக்கப்பட்டது: தொடர்பான தரவுத்தளத்தில் உள்ள தரவை வினவுவதற்கு எஸ்.கியூ.எல் ஆனது C அல்லது BASIC போன்ற ஏவல் மொழியாக இல்லாமல் தொகுதி-அடிப்படையிலான அறிவித்தல் வினவல் மொழியாக இருக்கும். இருப்பினும் நிர்மாணங்களின் ஓட்ட கட்டுப்பாடு போன்ற செயல்முறை நிரலாக்க மொழி செயல்திறனைச் சேர்க்கும் நிலையான எஸ்.கியூ.எல்லிற்கான நீட்டிப்புகள் உள்ளன. அவையாவன:

மூலம்: பொதுப்
பெயர்
முழுப்பெயர்
ANSI/ISO தரநிலை SQL/PSM எஸ்.கியூ.எல்/நிலையான சேமிக்கப்பட்ட தொகுதிக்கூறுகள்
இண்டர்பேஸ்/
பையர்பேர்ட்
PSQL செயல்முறை எஸ்.கியூ.எல்
ஐபிஎம் SQL PL எஸ்.கியூ.எல் செயல்முறை மொழி(SQL/PSM ஐ நடைமுறைப்படுத்தும்)
மைக்ரோசாஃப்ட்
சைபேஸ்
T-SQL பரிமாற்ற-எஸ்.கியூ.எல்
மைஎஸ்.கியூ.எல் SQL/PSM எஸ்.கியூ.எல்/நிலையாக சேமிக்கப்பட்ட தொகுதிக்கூறுகள்(SQL/PSM ஐ நடைமுறைப்படுத்தும்)
ஆரக்கிள் PL/SQL செயல்முறை மொழி/எஸ்.கியூ.எல் (Ada அடிப்படையானது)
போஸ்ட்கெரேஎஸ்.கியூ.எல் PL/pgSQL செயல்முறை மொழி/போஸ்ட்கெரே கட்டமைக்கப்பட்ட வினவல் மொழி (ஆரக்கிள் PL/SQL அடிப்படையானது)
போஸ்ட்கெரேஎஸ்.கியூ.எல் PL/PSM செயல்முறை மொழி/நிலையான சேமிக்கப்பட்ட தொகுதிக்கூறுகள்(SQL/PSM ஐ நடைமுறைப்படுத்தும்)

நிலையான SQL/PSM நீட்டிப்புகள் மற்றும் சொத்துடமை உரிமை சார்ந்த எஸ்.கியூ.எல் நீட்டிப்புகளோடு செயல்முறை மற்றும் குறிக்கோள்-ரீதியான நிரலாக்கத்தன்மை ஆகியனவும் பிற மொழிகளுடன் DBMS ஒருங்கிணைவு வழியாக பல எஸ்.கியூ.எல் பணித்தளங்களில் கிடைக்கிறது. எஸ்.கியூ.எல் தரவுத்தளங்களில் ஜாவா குறியீட்டை ஆதரிப்பது என SQL/JRT நீட்டிப்புகளை (ஜாவா நிரலாக்க மொழிக்கான எஸ்.கியூ.எல் நடைமுறைகள் மற்றும் வகைகள்) எஸ்.கியூ.எல் தரநிலை வரையறுக்கிறது. எஸ்.கியூ.எல் சர்வர் 2005 ஆனது தரவுத்தளங்களிலுள்ள ஹோஸ்ட் நிர்வகித்த .NET கூட்டங்களுக்கு SQLCLR (எஸ்.கியூ.எல் சர்வர் காமன் லேங்வேஜ் ரண்டைம்) ஐப் பயன்படுத்துகிறது. அதேவேளை எஸ்.கியூ.எல் சர்வரின் முந்தைய பதிப்புகள் பிரதானமாக C இல் எழுதப்பட்ட நிர்வகிக்கப்படாத நீட்டிக்கப்பட்ட சேமிக்கப்பட்ட செயன்முறைகளைப் பயன்படுத்த வேண்டும் என வரம்பிடப்பட்டிருந்தன. மை எஸ்.கியூ.எல் மற்றும் போஸ்ட்கெரேஸ் போன்ற பிற தரவுத்தள பணித்தளங்கள் Perl, Python, Tcl, மற்றும் C போன்ற பல்வேறு மொழிகளில் செயல்பாடுகளை எழுத அனுமதிக்கும்.

எஸ்.கியூ.எல் பற்றிய விமர்சனங்கள் தொகு

எஸ்.கியூ.எல் என்பது தொடர்பான தரவுத்தளங்களுடன் பயன்படுத்துவதற்கான ஒரு அறிவித்தல் கணினி மொழி ஆகும். அசல் எஸ்.கியூ.எல் அம்சங்கள் பலவற்றை தொடர்பு மாதிரி மற்றும் இதன் டப்பிள் கால்குலஸ் அங்கீகாரத்தின் கருத்தானது ஊக்குவித்தது என்றாலும் அது மீறியுள்ளது. எஸ்.கியூ.எல்லிற்கான சமீபத்திய நீட்டிப்புகள் தொடர்பான பூர்த்தியை அடைந்துள்ளன. ஆனால் த தேர்ட் மானிஃபெஸ்டோ வில் ஆவணப்படுத்தியுள்ளதால் மீறல்களை மேலும் மோசமாக்கியுள்ளன.

எஸ்.கியூ.எல்லின் நடைமுறை விமர்சனங்களில் உள்ளடங்குபவை:

  • நடைமுறைப்படுத்தல்கள் நிலையற்றவை, மேலும் பொதுவாக விற்பனையாளர்களிடையே இணக்கமற்றவை. குறிப்பாக தேதி மற்றும் நேர தொடரியல், சர சங்கிலி, சுழிகள் மற்றும் ஒப்பீட்டு எழுத்து உணர்தன்மை ஆகியன விற்பனையாளருக்கு விற்பனையாளர் மாறுபடுகிறது.
  • கார்ட்டீசியன் இணைப்பு (சாத்தியமான அனைத்து சேர்க்கைகளையும் இணைத்தல்) செய்யப்படுவதை மொழியானது மிகவும் எளிதாக்குகிறது. இது WHERE பிரிவுகள் தவறாக தட்டச்சுச் செய்யப்படும்போது "கட்டுப்பாட்டை மீறிய" முடிவுகளை வழங்கும். கார்ட்டீசியன் இணைப்புகள் தெளிவான CARTESIAN திறவுசொல் உத்தரவாதம் அளிக்கப்படவேண்டிய தேவை ஏற்படுகின்ற நடைமுறையில் மிகவும் அரிதாகவே பயன்படுத்தப்படுகின்றன. (எஸ்.கியூ.எல் 1992 ஆனது CROSS JOIN திறவுச்சொல்லை அறிமுகப்படுத்தியது. இது கார்ட்டீசியன் இணைப்பு வடிவமைக்கப்பட்டது என்று தெளிவுபடுத்த பயனரை அனுமதிக்கிறது. ஆனால் பயனிலை இல்லாத சுருக்கெழுத்து "கம்மா-இணைப்பு" இப்போதும் ஏற்றுக்கொள்ளக்கூடிய தொடரியல் ஆகும். இதனால் அதே தவறு மீண்டும் கொண்டு வருகிறது.)
  • மேலும் ஒரு புதுப்பிப்பு அல்லது நீக்கத்தில் WHERE ஐ தவறுதலாக கட்டமைக்கவும் சாத்தியமுள்ளது. இதனால் அட்டவணையிலுள்ள தேவையான வரிசைகளை விட கூடுதலான வரிசைகள் பாதிக்கப்படுகின்றன. (தற்காலிக தீர்வு என்னவென்றால் பரிமாற்றங்களைப் பயன்படுத்தல் அல்லது வழக்கம்போல WHERE பிரிவில் முதலில் தட்டச்சு செய்து மிகுதியைப் பிறகு நிரப்புதல்.)
  • செயல்பாடு ஆதிக்கமான தொடரியலானது சில இலக்கண மற்றும் தொடரியல் விதிகளை மீண்டும் பயன்படுத்துவதைக் கூடுதலாக ஏற்படுத்தும்போது, எஸ்.கியூ.எல் இலக்கணமானது COBOL-போன்ற திறவுச்சொல் அணுகுமுறையை எடுப்பதில் சிலவேளைகளில் அவசியமின்றி சிக்கலாக உள்ளது.

விற்பனையாளர் இடையேயான வசதி தொகு

எஸ்.கியூ.எல்லின் பிரபல செயலாற்றல்கள், DATE அல்லது TIME தரவு வகைகள் போன்ற நிலையான எஸ்.கியூ.எல்லின் அடிப்படை அம்சங்களை பொதுவாக ஆதரிக்காது. இதன் விளைவாக தரவுத்தள முறைகளுக்கு இடையே மாற்றங்கள் இல்லாமல் எஸ்.கியூ.எல் குறியீட்டை அரிதாகவே இடலாம்.

தரவுத்தள முறைகளுக்கிடையே இந்த வசதி இன்மைக்கு பல காரணங்கள் உள்ளன:

  • எஸ்.கியூ.எல் தரத்தின் சிக்கல்தன்மை மற்றும் அளவு என்பது பெரும்பாலான செயலாற்றுபவர்கள் தரம் முழுவதையும் ஆதரிப்பதில்லை.
  • எவ்வாறு நடந்துகொள்வது என தீர்மானிக்க செயலாற்றல்களை அனுமதிக்கும் பல முக்கிய பகுதிகளில் (எ.கா., அட்டவணைகள், கோப்பு சேமிப்பு) தரமானது தரவுத்தள நடத்தையைக் குறிப்பதில்லை.
  • சரிசெய்யும் தரவுத்தள முறை ஒன்றைக் கட்டாயம் செயல்படுத்த வேண்டும் என்ற தொடரியலை எஸ்.கியூ.எல் தரம் துல்லியமாக குறிப்பிடுகிறது. இருப்பினும் மொழிக் கட்டமைப்பு கருத்துக்களின் தரத்தின் விவரக்குறிப்பானது ஓரளவே நன்றாக வரையறுக்கப்பட்டது. எனவே பல பொருளைக் குறிக்கிறது.
  • பல தரவுத்தள விற்பனையாளர்களிடம் முன்பே உள்ள விற்பனையாளர்களின் பெரிய தளங்கள் உள்ளன. இங்கே எஸ்.கியூ.எல் தரமானது விற்பனையாளரின் தரவுத்தளத்தின் முந்தைய நடத்தையுடன் முரண்படுகிறது. விற்பனையாளர் பின்னோக்கிய இணக்கத்தன்மையை முறிக்க முடியாதவராக இருக்கக்கூடும்.
  • மென்பொருள் விற்பனையாளர்கள் பிற தயாரிப்புகளுடன் இணக்கமில்லாத தன்மையை உருவாக்கவே பெரும்பாலும் விரும்புகிறார்கள். ஏனெனில் தமக்கென உள்ள பயனர்களுக்கான நம்பிக்கையைத் தக்கவைக்க இது பலமான சலுகையாக இருக்கிறது (விற்பனையாளர் பூட்டு என்பதைக் காண்க).

தரநிலையாக்கம் தொகு

1986 ஆம் ஆண்டில் அமெரிக்கன் தேசிய தரநிலைகள் நிறுவனம் (ANSI) எஸ்.கியூ.எல்லை எஸ்.கியூ.எல்-86[16] ஆக தனது தரநிலையை வழங்கியது. மேலும் தரநிலையாக்கத்துக்கான சர்வதேச நிறுவனம் (ISO) 1987 ஆம் ஆண்டில் ஏற்றுக்கொண்டது. எஸ்.கியூ.எல்லிற்கான அதிகாரபூர்வ உச்சரிப்பு "எஸ் கியூ எல்" என்பதாக இருக்க வேண்டுமென அசல் எஸ்.கியூ.எல் தரம் தெரிவித்தது.[1] ஆனால் இன்றும் கூட பல ஆங்கிலம்-பேசும் தரவுத்தள நிபுணர்கள் ஏற்றுக்கொள்ளப்படாத [17] உச்சரிப்பைப் பயன்படுத்துகிறார்கள் /ˈsiːkwəl/ ("சீக்வெல்" என்ற சொல் போல). சீக்வெல் என்பது ஆரம்பகால ஐபிஎம் தரவுத்தள மொழி ஆகும். இது எஸ்.கியூ.எல் மொழிக்கு முந்தையது.[18]

1996 ஆம் ஆண்டு வரை தரநிலைகள் மற்றும் தொழில்நுட்பத்துக்கான தேசிய நிறுவன (NIST) தரவு மேலாண்மை தரநிலை திட்டமானது SQL DBMS ஆனது எஸ்.கியூ.எல் தரநிலையுடன் இணங்கும் என சான்றளித்தது. இப்போது தமது தயாரிப்புகளின் இணக்கநிலை குறித்து விற்பனையாளர்கள் தாமாகவே உறுதிப்படுத்துகிறார்கள்.[19]

கீழே காண்பிக்கப்படுவது போல எஸ்.கியூ.எல் தரநிலையானது பெருமளவு திருத்தங்களுக்கு உள்ளாகியுள்ளன:

ஆண்டு பெயர் மறுபெயர் கருத்துரைகள்
1986 எஸ்.கியூ.எல்-86 எஸ்.கியூ.எல்-87 முதலில் ஆன்சியால் (ANSI) அங்கீகரிக்கப்பட்டது.
1989 எஸ்.கியூ.எல்-89 FIPS 127-1 சிறிய திருத்தங்கள் செய்யப்பட்டு FIPS 127-1 ஆக மாற்றப்பட்டது.
1992 எஸ்.கியூ.எல்-92 எஸ்.கியூ.எல்2, FIPS 127-2 முதன்மை திருத்தம் (ISO 9075), உள்ளீட்டு நிலை எஸ்.கியூ.எல்-92 ஆனது FIPS 127-2 ஆக மாற்றப்பட்டது.
1999 எஸ்.கியூ.எல்:1999 எஸ்.கியூ.எல்3 சாதாரண கோவைப் பொருத்தம், சூத்திர வினவல்கள், தூண்டிகள், செயல்முறை மற்றும் ஓட்ட வாக்கியங்களின் கட்டுப்பாடு, மாறா வகைகள் மற்றும் சில குறிக்கோள் ரீதியிலான அம்சங்கள் ஆகியன சேர்க்கப்பட்டன.
2003 எஸ்.கியூ.எல்:2003   எக்ஸ்.எம்.எல்-தொடர்பான அம்சங்கள், சாளர செயல்பாடுகள், தரநிலையாக்கப்பட்ட தொடர்கள், மற்றும் தானாக உருவாக்கப்பட்ட மதிப்புகளுடன் நெடுவரிசைகள் ஆகியன அறிமுகம் செய்யப்பட்டன(அடையாள-நெடுவரிசைகள் உள்ளடங்கலாக).
2006 எஸ்.கியூ.எல்:2006   எக்ஸ்.எம்.எல்லுடன் சேர்த்து எந்த வழிகளில் எஸ்.கியூ.எல்லைப் பயன்படுத்தலாம் என்பதை ISO/IEC 9075-14:2006 வரையறுக்கிறது. இது எஸ்.கியூ.எல் தரவுத்தளத்தில் எக்ஸ்.எம்.எல் தரவுகளை இறக்குமதி செய்து சேமிப்பது, தரவுத்தளத்திற்குள் இதைக் கையாள்வது மற்றும் எக்ஸ்.எம்.எல் மற்றும் மரபு ரீதியான எஸ்.கியூ.எல்-தரவு இரண்டையும் எக்ஸ்.எம்.எல் வடிவத்தில் வெளியிடுவது ஆகியவற்றுக்கான வழிகளை வரையறுக்கிறது. மேலும், பயன்பாடுகளை அவற்றின் எஸ்.கியூ.எல் குறியீடு, வைய விரி வலை கன்சார்ட்டியத்தால் (W3C) வெளியிடப்பட்ட XQuery பயன், எக்ஸ்.எம்.எல் வினவல் மொழிக்குள் ஒருங்கிணையவும், சம நேரத்தில் சாதாரண எஸ்.கியூ.எல்-தரவு மற்றும் எக்ஸ்.எம்.எல் ஆவணங்களை அணுகவும் செய்கிறது.
2008 எஸ்.கியூ.எல்:2008   இடஞ்சுட்டி வரையறைகளுக்கு வெளியே ORDER BY ஐ சட்டரீதியாக்குகிறது. INSTEAD OF தூண்டிகளைச் சேர்க்கிறது. TRUNCATE வாக்கியத்தைச் சேர்க்கிறது.[20]

ஆர்வமிக்க தரப்புகள் எஸ்.கியூ.எல் தரநிலைகளைகள் ஆவணங்களை ISO அல்லது ஆன்சியிடம் இருந்து வாங்கிக்கொள்ளலாம். எஸ்.கியூ.எல்:2008 இன் வரைவானது ஜிப் காப்பகமாக இலவசமாக கிடைக்கிறது.[21]

தரக் கட்டமைப்பு தொகு

எஸ்.கியூ.எல் தரமானது பல பகுதிகளாகப் பிரிக்கப்பட்டுள்ளது, அவையாவன:

எஸ்.கியூ.எல் கட்டமைப்பானது தர்க்கரீதியான கோட்பாட்டை வழங்குகிறது

SQL/Foundation, ISO/IEC 9075, பகுதி 2 இல் வரையறைக்கப்பட்டது. இந்தப் பகுதி தரநிலையானது மொழியின் பெரும்பாலான மைய உறுப்புகளைக் கொண்டிருக்கும். இதில் கடப்பாடுடைய மற்றும் விருப்ப அம்சங்கள் இரண்டையும் கொண்டிருக்கும்.

எஸ்.கியூ.எல்/பைண்டிங்க்ஸானது ஜாவா தவிர வேறுபட்ட ஹோஸ்ட் மொழிகளுடன் எவ்வாறு எஸ்.கியூ.எல்லைக் கட்டுண்டதாக்குவது என்பதை குறிப்பிடுகிறது.

SQL/CLI, அல்லது அழைப்பு-நிரல் இடைமுக பகுதியானது ISO/IEC 9075, பகுதி 3 இல் வரையறுக்கப்பட்டுள்ளது. SQL/CLI ஆனது சாதாரண இடைமுகவாக்க கூறுகளை வரையறுக்கிறது (கட்டமைப்புகள் மற்றும் செயல்முறைகள்), வேறு நிரலாக்க மொழிகளில் எழுதப்பட்ட பயன்பாடுகளிலிருந்து எஸ்.கியூ.எல் வாக்கியங்களைச் செயல்படுத்த இதைப் பயன்படுத்த முடியும். எஸ்.கியூ.எல் வாக்கியங்கள் மற்றும் SQL/CLI செயல்முறை அழைப்புகள் ஆகியன அழைப்பு பயன்பாட்டின் மூல குறியீட்டிலிருந்து வேறுபட்டதாகவே கையாளப்படும் என்ற விதத்தில் SQL/CLI ஆனது வரையறுக்கப்படும். திறந்த தரவுத்தள இணைப்புநிலை என்பது SQL/CLI இன் நன்கறியப்பட்ட மூலக்கணமாகும். இந்தப்பகுதி தரநிலையானது கடப்பாடுடைய அம்சங்களை மட்டுமே கொண்டிருக்கும்.

SQL/PSM அல்லது நிலையான சேமிக்கப்பட்ட தொகுதிக்கூறுகள் பகுதியானது ISO/IEC 9075, பகுதி 4 ஆல் வரையறுக்கப்படுகிறது. SQL/PSM ஆனது ஓட்ட கட்டுப்பாடு, நிபந்தைக் கையாளல், வாக்கிய நிலை சமிக்ஜைகள் மற்றும் மறுசமிக்ஜைகள், இடஞ்சுட்டிகள் மற்றும் அக மாறிகள் உள்ளடங்கலாக எஸ்.கியூ.எல்லிற்கான செயல்முறை நீட்டங்களையும் மாறிகள் மற்றும் அளவுருக்களுக்கு கோவைகளின் ஒதுக்கங்களையும் தரநிலைப்படுத்துகிறது. மேலும், நிலையான தரவுத்தள மொழி வழிவகைகளின் தீர்மான அறிவித்தல் மற்றும் பராமரிப்பை SQL/PSM மதிப்பீடு செய்கிறது (எ.கா., "சேமிக்கப்பட்ட செயல்முறைகள்"). இந்தப் பகுதி தரநிலையானது விருப்ப அம்சங்களை மட்டுமே கொண்டிருக்கும்.

SQL/MED அல்லது புற தரவுகளை நிர்வகித்தல் பகுதியானது ISO/IEC 9075, பகுதி 9 ஆல் வரையறுக்கப்படுகிறது. SQL/MED ஆனது எஸ்.கியூ.எல்லிற்கு நீட்டிப்புகளை வழங்குகிறது. இவை வெளிப்புற தரவை நிர்வகிக்க எஸ்.கியூ.எல்லை அனுமதிப்பதற்கு வெளி-தரவு மேலுறைகள் மற்றும் தரவு இணைப்பு வகைகளை வரையறுக்கின்றன. வெளிப்புற தரவு என்பது எஸ்.கியூ.எல்-அடிப்படையான DBMS ஆல் அணுகக்கூடிய ஆனால் நிர்வகிக்க முடியாத தரவாகும். இந்தப் பகுதி தரநிலையானது விருப்ப அம்சங்களை மட்டுமே கொண்டிருக்கும்.

SQL/OLB அல்லது குறிக்கோள் மொழி கட்டமைப்புகள் பகுதியானது ISO/IEC 9075, பகுதி 10 ஆல் வரையறுக்கப்படுகிறது. SQL/OLB ஆனது ஜாவாவில் உட்பொதிந்துள்ள எஸ்.கியூ.எல் ஆன SQLJ இன் தொடரியல் மற்றும் சிமாண்டிக்ஸை வரையறுக்கிறது. இந்த தரநிலையானது SQLJ பயன்பாடுகளின் பைனரி வசதியை உறுதிப்படுத்தும் பொறிமுறைகளையும் கூட விபரிக்கிறது, வேறுபட்ட ஜாவா தொகுதிகள் மற்றும் அவை கொண்டுள்ள பிரிவுகளைக் குறிப்பிடுகிறது. இந்தப் பகுதி தரநிலையானது விருப்ப அம்சங்களை மட்டுமே கொண்டிருக்கும்.

SQL/MM (மல்டிமீடியா), இது வீடியோ, ஆடியோ மற்றும் இடநிலை தரவுகள் போன்ற பெரிய, சிக்கலான மற்றும் சிலவேளைகளில் தொடரோடுகின்ற தரவு உருப்படிகளுடன் புத்திசாலித்தனமாக எஸ்.கியூ.எல்லை தொடர்பு கொள்ள வைக்கும்.

SQL/அமைப்பியல்கள் அல்லது தகவல் மற்றும் வரையறை அமைப்பியல்கள் பகுதியானது ISO/IEC 9075 பகுதி 11 ஆல் வரையறுக்கப்படுகிறது. எஸ்.கியூ.எல்/அமைப்பியல்கள் தகவல் அமைப்பியல் மற்றும் வரையறை அமைப்பியலை வரையறுக்கின்றது. எஸ்.கியூ.எல் தரவுத்தளங்கள் மற்றும் குறிக்கோள்கள் சுய-விவரித்தலைச் செய்ய பொதுவான கருவிகளின் தொகுதியை வழங்குகிறது. இந்த கருவிகளில் எஸ்.கியூ.எல் குறிக்கோள் அடையாளங்காட்டி, அமைப்பு மற்றும் ஒருமைப்பாட்டு கட்டுப்பாடுகள், பாதுகாப்பு மற்றும் அங்கீகார விவரக்குறிப்புகள், அம்சங்கள் மற்றும் ISO/IEC 9075 தொகுப்புகள், எஸ்.கியூ.எல்-அடிப்படையிலான DBMS செயலாற்றல்கள் வழங்கிய அம்சங்களின் ஆதரவு, எஸ்.கியூ.எல்-அடிப்படையிலான DBMS செயலாற்றல் தகவல் மற்றும் அளவிடல் உருப்படிகள், மற்றும் DBMS செயலாற்றல்களால் ஆதரிக்கப்படும் மதிப்புகள் ஆகியன உள்ளடங்கும்.[22] இந்தப் பகுதி தரநிலையானது கடப்பாடுடைய மற்றும் விருப்ப அம்சங்கள் இரண்டையும் கொண்டிருக்கும்.

SQL/JRT அல்லது ஜாவா நிரலாக்க மொழிக்கான எஸ்.கியூ.எல் வழிவகைகள் மற்றும் வகைகள் பகுதியானது ISO/IEC 9075 பகுதி 13 ஆல் வரையறுக்கப்படுகிறது. SQL/JRT ஆனது நிலையான ஜாவா முறைகளை எஸ்.கியூ.எல் பயன்பாடுகளிலிருந்து வழி வகைகள் என குறிப்பிடுவதற்கான திறனைக் குறிப்பிடுகிறது. ஜாவா பிரிவுகளை எஸ்.கியூ.எல் கட்டமைக்கப்பட்ட பயனர்-வரையறுத்த வகைகளாக பயன்படுத்துவதற்கான திறனை இதுவும் எதிர்பார்க்கிறது. இந்தப் பகுதி தரநிலையானது விருப்ப அம்சங்களை மட்டுமே கொண்டிருக்கும்.

SQL/XML, அல்லது எக்ஸ்.எம்.எல்-தொடர்புடைய விவரக்குறிப்புகள் பகுதியானது ISO/IEC 9075, பகுதி 14 ஆல் வரையறுக்கப்படுகிறது. SQL/XML ஆனது எஸ்.கியூ.எல்லுடன் இணைந்து எக்ஸ்.எம்.எல்லைப் பயன்படுத்துவதற்கான எஸ்.கியூ.எல்-அடிப்படையிலான நீட்டங்களைக் குறிப்பிடப்பட்டு எக்ஸ்.எம்.எல் தரவு வகை அறிமுகப்படுத்தப்படுகிறது. மேலும் பல வழிவகைகள், செயல்பாடுகள், மற்றும் எஸ்.கியூ.எல் தரவுத்தளத்தில் எக்ஸ்.எம்.எல்லைக் கையாளுதல் மற்றும் சேமிப்புக்கு ஆதரவளிக்கும் எக்ஸ்.எம்.எல்-இருந்து-எஸ்.கியூ.எல் தரவு வகை மேப்பிங்குகள் ஆகியவற்றையும் கூட. இந்தப் பகுதி தரநிலையானது விருப்ப அம்சங்களை மட்டுமே கொண்டிருக்கும்.

எஸ்.கியூ.எல்லிற்கான மாற்றுக்கள் தொகு

தொடர்புடைய வினவல் மொழிகளுக்கான மாற்றுக்களுக்கும், எஸ்.கியூ.எல்லிற்கான மாற்றுக்களுக்கும் இடையில் ஒரு வேறுபாட்டை உருவாக்க வேண்டும். கீழேயுள்ளவை எஸ்.கியூ.எல்லிற்காக தீர்மானிக்கப்பட்ட தொடர்புடைய மாற்றுக்களாகும். தொடர்புடையவற்றுக்கான மாற்றுக்களுக்கு வழிநடத்தும் தரவுத்தளத்தை காண்க:

குறிப்புதவிகள் தொகு

  1. 1.0 1.1 Chapple, Mike. "SQL Fundamentals". About.com: Databases. About.com. Archived from the original on 2009-02-22. பார்க்கப்பட்ட நாள் 2009-01-28.
  2. Beaulieu, Alan (April 2009). Mary E. Treseler. ed. Learning SQL (2nd ). Sebastapol, CA, USA: O'Reilly. பன்னாட்டுத் தரப்புத்தக எண்:978-0-596-52083-0. https://archive.org/details/learningsql0000beau_p5d6. 
  3. Chamberlin, Donald D.; Boyce, Raymond F. (1974). "SEQUEL: A Structured English Query Language" (PDF). Proceedings of the 1974 ACM SIGFIDET Workshop on Data Description, Access and Control (Association for Computing Machinery): 249–264. http://www.almaden.ibm.com/cs/people/chamberlin/sequel-1974.pdf. பார்த்த நாள்: 2007-06-09. 
  4. 4.0 4.1 Oppel, Andy (1 March 2004). Databases Demystified. San Francisco, CA: McGraw-Hill Osborne Media. பக். 90–91. பன்னாட்டுத் தரப்புத்தக எண்:0-07-225364-9 இம் மூலத்தில் இருந்து 14 ஜூலை 2011 அன்று. பரணிடப்பட்டது.. https://web.archive.org/web/20110714082358/http://www.mhprofessional.com/product.php?cat=112&isbn=0072253649. பார்த்த நாள்: 19 பிப்ரவரி 2010. 
  5. "History of IBM, 1978". IBM Archives. IBM. பார்க்கப்பட்ட நாள் 2007-06-09.
  6. ANSI/ISO/IEC சர்வதேச தரநிலை (IS). தரவுத்தள மொழி எஸ்.கியூ.எல்—பகுதி 2: நிர்மாணம் (SQL/Foundation). 1999.
  7. "INTO Clause (Transact-SQL)". SQL Server 2005 Books Online. Microsoft. 2007. பார்க்கப்பட்ட நாள் 2007-06-17;. {{cite web}}: Check date values in: |accessdate= (help)CS1 maint: extra punctuation (link)
  8. ISO/IEC (2003). ISO/IEC 9075-1:2003, "SQL/Framework". ISO/IEC. Section 4.4.2: The null value. http://www.iso.org. 
  9. Coles, Michael (2005-06-27). "Four Rules for Nulls". SQL Server Central (Red Gate Software). http://www.sqlservercentral.com/columnists/mcoles/fourrulesfornulls.asp. 
  10. ISO/IEC. ISO/IEC 9075-2:2003, "SQL/Foundation". ISO/IEC. 
  11. எம். நேக்ரி, ஜி. பெலகட்டி, எல். ஸ்பாட்டெல்லா (1989) செமாண்டிக்ஸ் அண்ட் ப்ராப்ளம்ஸ் ஆஃப் யூனிவர்சல் குவாண்டிஃபிக்கேஷன் இன் எஸ்.கியூ.எல்.
  12. ஃப்ராடர்காஞ்சலி, கிளௌடியோ (1991). டெக்னிக்ஸ் ஃபார் யூனிவர்சல் குவாண்டிஃபிக்கேஷன் இன் எஸ்.கியூ.எல் . ACM.org. இலிருந்து பெறப்பட்டது.
  13. கவாஷ், ஜலால் (2004). காம்ப்ளக்ஸ் குவாண்டிஃபிக்கேஷன் இன் ஸ்ட்ரக்ஷர்ட் குவரி லேங்வேஜ் (எஸ்.கியூ.எல்): எ டுட்டோரியல் யூசிங் ரிலேஷனல் கால்குலஸ் - ஜேர்னல் ஆஃப் கம்ப்யூட்டர்ஸ் இன் மாதமெட்டிக்ஸ் அண்ட் சயின்ஸ் டீச்சிங் ISSN 0731-9258 தொகுப்பு 23, வெளியீடு 2, 2004 AACE நார்ஃபால்க், வர்ஜீனியா. Thefreelibrary.com இலிருந்து பெறப்பட்டது
  14. இன்ஃபார்மேஷன் டெக்னாலஜி - டேட்டாபேஸ் லேங்வேஜ் எஸ்.கியூ.எல் (புரப்போஸ்ட் ரிவைஸ்ட் டெக்ட் ஆஃப் DIS 9075)
  15. அரீ ஜோன்ஸ், ரியான் கே. ஸ்டீஃபன்ஸ், ரொனால்ட் ஆர். ப்ளீ, அலெக்ஸ் க்ரீகல், ராபர்ட் எஃப். கார்ரெட்(2005), எஸ்.கியூ.எல் ஃபாங்ஷன்ஸ் ப்ராகிரமர்ஸ் ரிஃப்ரன்ஸ் . விலே, 127 பக்கங்கள்
  16. அமெரிக்கன் தேசிய தரநிலைகள் நிறுவனம். X3H2 பதிவுகள், 1978-1995. ஃபைண்டிங் எய்ட்.
  17. Melton, Jim; Alan R Simon (1993). Understanding the New SQL: A Complete Guide. Morgan Kaufmann. பக். 536. பன்னாட்டுத் தரப்புத்தக எண்:1558602453. https://archive.org/details/understandingnew00melt. "chapter 1.2 What is SQL? SQL (correctly pronounced "ess cue ell," instead of the somewhat common "sequel"), is a..." 
  18. "Understand SQL". www.faqs.org/docs/.
  19. Doll, Shelley (19 June 2002). "Is SQL a Standard Anymore?". TechRepublic's Builder.com. TechRepublic. Archived from the original on 2012-07-05. பார்க்கப்பட்ட நாள் 2010-01-07.
  20. "Sybase.com". Archived from the original on 2011-06-28. பார்க்கப்பட்ட நாள் 2010-02-19.
  21. வைட்மார்ஷ் இன்ஃபார்மேஷன் சிஸ்டம்ஸ் கார்ப்பரேஷனிலிருந்து ஜிப் ஆர்ச்சிவ் ஆஃப் தி எஸ்.கியூ.எல்:2008 ட்ராஃப்ட்.
  22. ISO/IEC 9075-11:2008: Information and Definition Schemas (SQL/Schemata). 2008. p. 1. 

வெளி இணைப்புகள் தொகு