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

क्या MySQL में विदेशी कुंजियों का परिचय प्रदर्शन को कम करता है

मान लें:

  1. आप पहले से ही एक स्टोरेज इंजन का उपयोग कर रहे हैं जो FK (यानी:InnoDB) का समर्थन करता है
  2. आपके पास शामिल स्तंभों पर पहले से ही अनुक्रमणिकाएं हैं

तब मुझे लगता है कि MySQL को अखंडता लागू करने से आपको बेहतर प्रदर्शन मिलेगा। संदर्भात्मक अखंडता को लागू करना, आखिरकार, कुछ ऐसा है जिसे करने के लिए डेटाबेस इंजनों को अनुकूलित किया जाता है। रूबी में अखंडता को प्रबंधित करने के लिए अपना खुद का कोड लिखना तुलना में धीमा होने वाला है।

यदि आपको FK कार्यक्षमता प्राप्त करने के लिए MyISAM से InnoDB में जाने की आवश्यकता है, तो आपको दो इंजनों के बीच प्रदर्शन में ट्रेडऑफ़ पर विचार करने की आवश्यकता है।

यदि आपके पास पहले से संकेत नहीं हैं, तो आपको यह तय करने की आवश्यकता है कि क्या आप उन्हें चाहते हैं। सामान्यतया, यदि आप लिखने की तुलना में अधिक पढ़ रहे हैं, तो आप चाहते हैं (आवश्यकता, यहां तक ​​​​कि) संकेत।

वर्तमान में अनुक्रमित सामग्री के शीर्ष पर एक एफके को ढेर करना आपके आवेदन कोड में उन प्रकार के चेक को लागू करने से कम समग्र प्रदर्शन हिट का कारण बनना चाहिए।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. मैसकल टेबल कॉलम खाली नहीं हो सकता

  2. क्वेरी में MySQL में आदेश बनाए रखना

  3. यह परिणाम केवल फॉरवर्ड परिणाम सेट है, आगे बढ़ने के बाद रिवाइंड () को कॉल करना समर्थित नहीं है - Zend

  4. मैं नमूना Mysql डेटाबेस कहाँ से डाउनलोड कर सकता हूँ?

  5. क्या मेरे MySQL सर्वर कनेक्शन एन्क्रिप्टेड और सुरक्षित हैं?