வெளியில் சேர்வதற்கான காரணங்கள்

சொல்லப்போனால், நாங்கள் எங்கள் விரிதாள்களை ஒன்றிணைத்ததும், இன்னும் துப்புரவாளர் இல்லாததால் எங்களின் அலுவலகத்தை சுத்தம் செய்யும் பணிகள் காணாமல் போனதும் உங்களுக்கு நினைவிருக்கிறதா?

இது போன்ற வினவலை இயக்கினால்:

SELECT * FROM task

பின்னர் இந்த முடிவைப் பெறுகிறோம்:

ஐடி பணியாளர்_ஐடி பெயர் காலக்கெடுவை
1 1 முகப்பில் ஒரு பிழையை சரிசெய்யவும் 2022-06-01
2 2 பின்தளத்தில் ஒரு பிழையை சரிசெய்யவும் 2022-06-15
3 5 காபி வாங்கு 2022-07-01
4 5 காபி வாங்கு 2022-08-01
5 5 காபி வாங்குவார் 2022-09-01
6 (ஏதுமில்லை) அலுவலகத்தை சுத்தம் செய்யுங்கள் (ஏதுமில்லை)
7 4 வாழ்க்கையை அனுபவிக்கவும் (ஏதுமில்லை)
8 6 வாழ்க்கையை அனுபவிக்கவும் (ஏதுமில்லை)

Employee_id மூலம் பணியாளர் அட்டவணையுடன் பணி அட்டவணையை இணைக்க முயற்சித்தால் "Clear Office" பணி மறைந்துவிடும்.

இந்தச் சிக்கலைத் தீர்க்க, JOIN ஆபரேட்டருக்கு பல்வேறு மாற்றிகள் சேர்க்கப்பட்டுள்ளன, அவை அத்தகைய அனாதை வரிசைகளை மற்றொரு அட்டவணையில் ஒரு ஜோடி இல்லாமல் சேமிக்க அனுமதிக்கின்றன.

JOIN ஆபரேட்டரின் உன்னதமான வடிவத்தை உங்களுக்கு நினைவூட்டுகிறேன்:

table 1 JOIN table 2 ON condition

இடது அட்டவணையில் (அட்டவணை 1) உள்ள அனைத்து தரவும் இணைந்த அட்டவணையில் இருப்பதை உறுதிசெய்ய SQL சேவையகத்திடம் கூறலாம். சரியான அட்டவணையில் அவர்களுக்கு ஜோடி இல்லையென்றாலும். இதைச் செய்ய, நீங்கள் எழுத வேண்டும்:

table 1 LEFT JOIN table 2 ON condition

இணைக்கப்பட்ட அட்டவணையில் சரியான அட்டவணையில் இருந்து அனைத்து வரிசைகளும் இருக்க வேண்டுமெனில் , நீங்கள் எழுத வேண்டும்:

table 1 RIGHT JOIN table 2 ON
 condition

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

SELECT * FROM employee e RIGHT JOIN task t ON e.id = t.emploee_id

மற்றும் இந்த வினவலின் முடிவு:

ஐடி பெயர் தொழில் சம்பளம் வயது சேரும் நாள் ஐடி பணியாளர்_ஐடி பெயர்
1 இவனோவ் இவான் புரோகிராமர் 100000 25 2012-06-30 1 1 முகப்பில் ஒரு பிழையை சரிசெய்யவும்
2 பெட்ரோவ் பெட்ர் புரோகிராமர் 80000 23 2013-08-12 2 2 பின்தளத்தில் ஒரு பிழையை சரிசெய்யவும்
4 ரபினோவிச் மொய்ஷா இயக்குனர் 200000 35 2015-05-12 7 4 வாழ்க்கையை அனுபவிக்கவும்
5 கிரியென்கோ அனஸ்தேசியா அலுவலக மேலாளர் 40000 25 2015-10-10 3 5 காபி வாங்கு
5 கிரியென்கோ அனஸ்தேசியா அலுவலக மேலாளர் 40000 25 2015-10-10 4 5 காபி வாங்கு
5 கிரியென்கோ அனஸ்தேசியா அலுவலக மேலாளர் 40000 25 2015-10-10 5 5 காபி வாங்கு
6 வாஸ்கா பூனை 1000 3 2018-11-11 8 6 வாழ்க்கையை அனுபவிக்கவும்
(ஏதுமில்லை) (ஏதுமில்லை) (ஏதுமில்லை) (ஏதுமில்லை) (ஏதுமில்லை) (ஏதுமில்லை) 6 (ஏதுமில்லை) அலுவலகத்தை சுத்தம் செய்யுங்கள்

எங்கள் அட்டவணையில் மற்றொரு வரிசை சேர்க்கப்பட்டுள்ளது, சுவாரஸ்யமாக, அதில் நிறைய NULL மதிப்புகள் உள்ளன. பணியாளர் அட்டவணையில் இருந்து எடுக்கப்பட்ட அனைத்து தரவுகளும் NULL ஆக காட்டப்படும், ஏனெனில் "சுத்தமான அலுவலகம்" பணிக்காக பணியாளர் அட்டவணையில் இருந்து செயல்படுத்துபவர் இல்லை.

வகைகளில் சேரவும்

மொத்தம் 4 வகையான JOINகள் உள்ளன. அவை கீழே உள்ள அட்டவணையில் வழங்கப்பட்டுள்ளன:

சுருக்கமான பதிவு நீண்ட நுழைவு விளக்கம்
1 சேரவும் உள் இணைப்பு ஏ மற்றும் பி அட்டவணையில் உள்ள பதிவுகள் மட்டுமே
2 இடதுபுறம் சேரவும் லெஃப்ட் அவுட்டர் ஜாயின் அட்டவணை A இலிருந்து ஒரு ஜோடி இல்லாத அனைத்து வரிசைகளும் இருக்க வேண்டும்
3 வலது சேரவும் வலதுபுறம் சேரவும் அட்டவணை B இலிருந்து ஒரு ஜோடி இல்லாத அனைத்து வரிசைகளும் இருக்க வேண்டும்
4 வெளியே சேரவும் முழு வெளியில் சேரவும் அட்டவணை A மற்றும் B இலிருந்து அடிப்படை ஜோடிகளின் அனைத்து வரிசைகளும் இருக்க வேண்டும்

எளிமைக்காக, அட்டவணைகளை தொகுப்பாகக் குறிப்பிடுகிறோம் என்றால், JOIN என்பது படமாக காட்டப்படும்:

செட் குறுக்குவெட்டு என்பது ஒரு அட்டவணைக்கு அது குறிப்பிடும் மற்றொரு அட்டவணையில் இருந்து தொடர்புடைய பதிவு உள்ளது.

நேர்காணலில் இருந்து கேள்வி

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

" பணிகள் இல்லாத அனைத்து ஊழியர்களின் பட்டியலைக் காண்பிக்கும் வினவலை எழுதவும் ." முதலில், இந்தக் கேள்வியை மீண்டும் எழுத முயற்சிப்போம்: " பணி அட்டவணையில் பணிகள் இல்லாத பணியாளர் அட்டவணையில் இருந்து அனைத்து ஊழியர்களின் பட்டியலைக் காண்பிக்கும் வினவலை எழுதவும் ." இந்த தொகுப்பை நாம் பெற வேண்டும்:

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

SELECT * FROM employee e LEFT JOIN task t ON e.id = t.emploee_id  
WHERE t.id IS NULL 

மற்றும் இந்த வினவலின் முடிவு:

ஐடி பெயர் தொழில் சம்பளம் வயது சேரும் நாள் ஐடி பணியாளர்_ஐடி பெயர்
3 இவனோவ் செர்ஜி சோதனையாளர் 40000 முப்பது 2014-01-01 (ஏதுமில்லை) (ஏதுமில்லை) (ஏதுமில்லை)

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

இதைச் செய்ய, பணியாளர் அட்டவணையின் தேவையான நெடுவரிசைகளை நீங்கள் SELECT இல் பட்டியலிட வேண்டும் அல்லது அவை அனைத்தையும் காட்ட வேண்டும் என்றால், பின்வரும் கட்டுமானத்தை நீங்கள் எழுதலாம்:

SELECT e.* FROM employee e, task t 

முழுமையான கோரிக்கை இப்படி இருக்கும்:

SELECT e.*  
FROM employee e RIGHT JOIN task t ON e.id = t.emploee_id  
WHERE t.id IS NULL 

இந்த வினவலின் முடிவு:

ஐடி பெயர் தொழில் சம்பளம் வயது சேரும் நாள்
3 இவனோவ் செர்ஜி சோதனையாளர் 40000 முப்பது 2014-01-01

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