Skip to main content

ஒரு தரவுத்தளத்தில் பல முதல் உறவுகள்

Anonim

அட்டவணையின் A இல் உள்ள ஒவ்வொன்றும் அட்டவணை B இல் உள்ள பல இணைக்கப்பட்ட பதிவுகள் இருக்கலாம், ஆனால் அட்டவணை B இல் உள்ள ஒவ்வொன்றும் அட்டவணையில் A. ஒரே ஒரு ஒத்த பதிவு மட்டுமே இருக்கும் போது ஒரு தரவுத்தளத்தில் ஒரு பல உறவு ஏற்படுகிறது. ஒரு தரவுத்தளம் மிகவும் பொதுவான தரவுத்தள வடிவமைப்பாகும் மற்றும் நல்ல வடிவமைப்பு இதயத்தில் உள்ளது.

ஒரு ஆசிரியருக்கும் அவர்கள் கற்பிக்கும் படிப்புக்கும் இடையிலான உறவைக் கவனியுங்கள். ஒரு ஆசிரியர் பல படிப்புகளை கற்பிப்பார், ஆனால் ஆசிரியருடன் அதே உறவு இருக்காது.

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

ஒருவருடன் பல உறவுகளை நிறுவுவது முக்கியம்

ஒருவருடன் பல உறவுகளை பிரதிநிதித்துவப்படுத்துவதற்காக குறைந்தது இரண்டு அட்டவணைகள் தேவை. ஏன் என்று பார்ப்போம்.

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

ஆசிரியர்கள் மற்றும் பாடநெறிகள்
Teacher_IDTeacher_Nameகோர்ஸ்
Teacher_001கார்மென்உயிரியல்
Teacher_002வெரோனிகாகணித
Teacher_003ஜார்ஜ்ஆங்கிலம்

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

ஆசிரியர்கள் மற்றும் பாடநெறிகள்
Teacher_IDஆசிரியர்_Nameகோர்ஸ்
Teacher_001கார்மென்உயிரியல், கணிதம்
Teacher_002வெரோனிகாகணித
Teacher_003ஜார்ஜ்ஆங்கிலம்

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

இது தரவு தேட கடினமாக உள்ளது. இந்த வடிவமைப்பானது தரவுத்தள இயல்பாக்கம், முதல் இயல்புநிலை படிவம் (1NF) முதல் கொள்கைகளை மீறுகிறது, ஒவ்வொரு அட்டவணையில் ஒரு ஒற்றை, தனித்தனி தரவுகளைக் கொண்டிருக்க வேண்டும் என்று கூறுகிறது.

மற்றொரு வடிவமைப்பு மாற்று கார்மன் ஐந்து இரண்டாவது பதிவு சேர்க்க வேண்டும்:

ஆசிரியர்கள் மற்றும் பாடநெறிகள்
ஆசிரியர்_IDஆசிரியர்_Nameகோர்ஸ்
Teacher_001கார்மென்உயிரியல்
Teacher_001கார்மென்கணித
Teacher_002வெரோனிகாகணித
Teacher_003ஜார்ஜ்ஆங்கிலம்

இது 1NF க்கு முரணானது ஆனால் இன்னும் மோசமான தரவுத்தள வடிவமைப்பாக இருக்கிறது, ஏனென்றால் இது பணிநீக்கத்தை அறிமுகப்படுத்துகிறது மற்றும் தேவையற்ற முறையில் மிகப்பெரிய தரவுத்தளத்தை வீசுகிறது. மிக முக்கியமாக, தரவு சீரற்றதாகிவிடும். உதாரணமாக, கார்மென் பெயரை மாற்றினால் என்ன செய்வது? தரவோடு பணிபுரிபவருக்கு ஒருவர் ஒரு பதிவில் தனது பெயரை புதுப்பித்து, இரண்டாவது பதிப்பில் அதை புதுப்பிக்கத் தவறிவிடலாம். இந்த வடிவமைப்பு இரண்டாவது இயல்பான படிவத்தை (2NF) மீறுகிறது, இது 1NF க்கு ஒத்துப் போகிறது, மேலும் தரவு பலவற்றை பல அட்டவணைகளாக பிரிக்கவும் அவற்றுக்கு இடையேயான உறவை உருவாக்குவதன் மூலம் பல பதிவுகளின் நீக்குதல்களை தவிர்க்கவும் வேண்டும்.

ஒரு பல உறவுகளுடன் ஒரு தரவுத்தள வடிவமைக்க எப்படி

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

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

ஆசிரியர்கள்
ஆசிரியர்_IDஆசிரியர்_Name
Teacher_001கார்மென்
Teacher_002வெரோனிகா
Teacher_003ஜார்ஜ்

இங்கு பாடநெறி அட்டவணை. அதன் வெளிநாட்டு கீ, ஆசிரியர்_ஐடி ஆசிரியருக்கான ஆசிரியருக்கு ஒரு பாடத்தை இணைக்கிறது:

படிப்புகள்
Course_IDபடிப்பின் பெயர்Teacher_ID
Course_001உயிரியல்Teacher_001
Course_002கணிதTeacher_001
Course_003ஆங்கிலம்Teacher_003

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

இது உயிரியல் மற்றும் கணித இருவரும் கார்மென் மூலமாக கற்பிக்கப்படுகிறது மற்றும் ஜார்ஜ் ஆங்கிலத்தில் கற்பிக்கிறார் என்று நமக்கு சொல்கிறது.

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

தரவுத்தளங்கள் ஒருவருடன் ஒரு உறவுமுறையும் ஒரு பல-பல உறவுகளையும் செயல்படுத்தலாம்.