Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

क्या किसी तालिका को गतिशील रूप से सामान्य करना व्यावहारिक है?

यह आपके उपयोग पर थोड़ा सा निर्भर करता है। सामान्यीकृत दृष्टिकोण (पार्क एक टेबल है) निम्नलिखित प्रश्नों को आसान बना देगा:

  • प्रत्येक पार्क में कितने पक्षी देखे गए हैं
  • आप किस पार्क में XYZ पक्षी देखने की सबसे अधिक संभावना रखते हैं
  • शायद इस तरह की कुछ और क्वेरीज़ हैं

लेकिन हाँ, आप कुछ चिपचिपे मुद्दों में भाग लेते हैं। पैटर्न "यदि पार्क XYZ मौजूद नहीं है तो इसे पार्क टेबल में डालें" एक दौड़ की स्थिति से ग्रस्त है जिससे आपको निपटना होगा।

अब, यहां सामान्यीकरण के खिलाफ कुछ तर्कों के बारे में कैसे ... अधिकांश ग्राहक डेटाबेस शायद सड़क के नाम को गतिशील रूप से सामान्य किए बिना मेरे सड़क के पते को "123 फू स्ट्रीट" के रूप में संग्रहीत करते हैं (हम एक सड़क तालिका रख सकते हैं और वहां "फू स्ट्रीट" डाल सकते हैं, फिर संदर्भ इसे अन्य तालिकाओं से। मैं इसे क्यों लाऊं, यह दिखाने के लिए कि जो लोग किसी भी दोहराए गए डेटा से नफरत करते हैं, वे शायद स्वीकार करेंगे कि कुछ ऐसी रेखा है जिसे आपको पार करने की आवश्यकता नहीं है।

एक और मूर्खतापूर्ण उदाहरण यह होगा कि हम उपनाम साझा कर सकते हैं। क्या हमें वास्तव में अद्वितीय अंतिम नामों के लिए एक तालिका और फिर अन्य तालिकाओं से विदेशी कुंजी की आवश्यकता है? कुछ एप्लिकेशन हो सकते हैं जहां यह सहायक होता है लेकिन 99% एप्लिकेशन के लिए, यह बहुत दूर जाता है। यह केवल अधिक काम है और कम या बिना किसी लाभ के कम प्रदर्शन करने वाला है।

तो मैं इस बात पर विचार करता हूं कि मैं तालिका से डेटा को वापस क्वेरी करने में सक्षम होना चाहता हूं। ईमानदारी से इस मामले में मैं शायद पार्कों के लिए एक अलग टेबल करूँगा। लेकिन अन्य मामलों में मैंने नहीं चुना है।

यह मेरे दो सेंट हैं, करों के बाद एक प्रतिशत।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySql कार्यक्षेत्र जाँच बाधा

  2. हाइबरनेट ऑनडिलेट कैस्केड MySQL के लिए काम नहीं कर रहा है लेकिन पोस्टग्रेज़ और एमएस-एसक्यूएल पर काम करता है

  3. स्व-संदर्भित mysql तालिका से अभिभावक-बाल पदानुक्रम पुनर्प्राप्त करें

  4. Laravel - विभिन्न मूल्यों के साथ कई रिकॉर्ड अपडेट करें

  5. चयन करें * जो mysql तालिका में उपयोगकर्ता पोस्टकोड से मेल खाता है?