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

mysql तालिका संरचना प्रस्ताव?

नहीं, यह एक रिलेशनल डेटाबेस के लिए एक खराब डिज़ाइन है। यह Entity-Attribute-Value का एक उदाहरण है डिजाईन। यह लचीला है, लेकिन यह संबंधपरक डेटाबेस होने के अर्थ के अधिकांश नियमों को तोड़ता है।

लचीले डेटाबेस के समाधान के रूप में ईएवी डिज़ाइन में उतरने से पहले, इस कहानी को पढ़ें:खराब कारमा .

अधिक विशेष रूप से, ईएवी के साथ कुछ समस्याओं में शामिल हैं:

  • आप नहीं जानते कि किसी दिए गए ID_NUM के लिए क्वेरी किए बिना कौन-सी विशेषताएँ मौजूद हैं।
  • आप NOT NULL के समकक्ष किसी भी विशेषता को अनिवार्य नहीं बना सकते।
  • आप डेटाबेस बाधाओं का उपयोग नहीं कर सकते।
  • आप SQL डेटा प्रकारों का उपयोग नहीं कर सकते; value कॉलम एक लंबा VARCHAR होना चाहिए।
  • विशेष रूप से MySQL में, प्रत्येक VARCHAR अपने स्वयं के डेटा पृष्ठ पर संग्रहीत होता है, इसलिए यह बहुत बेकार है।

जब आप ईएवी डिज़ाइन का उपयोग करते हैं तो प्रश्न भी अविश्वसनीय रूप से जटिल होते हैं। मैगेंटो, एक ओपन-सोर्स ईकॉमर्स प्लेटफॉर्म, ईएवी का व्यापक रूप से उपयोग करता है, और कई उपयोगकर्ता कहते हैं कि यदि आपको कस्टम रिपोर्ट की आवश्यकता है तो यह बहुत धीमा और क्वेरी करना कठिन है।

संबंधपरक होने के लिए, आपको प्रत्येक भिन्न विशेषता को उसके अपने कॉलम में, उसके अपने नाम और उपयुक्त डेटाटाइप के साथ संग्रहित करना चाहिए।

मैंने अपनी प्रस्तुति में ईएवी के बारे में अधिक लिखा है व्यावहारिक वस्तु-उन्मुख SQL में मॉडल और मेरे ब्लॉग पोस्ट में EAV FAIL , और मेरी पुस्तक में, SQL एंटीपैटर्न:डेटाबेस प्रोग्रामिंग के नुकसान से बचना



  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. JTable के एकल कॉलम पर MySQL डेटाबेस से छवियों को प्रदर्शित करना

  5. सभी तालिका/स्तंभ नामों को हाइबरनेट बैककोट करें