MySQL EXPLAIN ANALYZE की व्याख्या: निष्पादन योजनाओं को पढ़ें और क्वेरीज़ को अनुकूलित करें (8.0 गाइड)

目次

1. परिचय

एक्जीक्यूशन प्लान: डेटाबेस प्रदर्शन अनुकूलन के लिए आवश्यक

वेब एप्लिकेशन और व्यावसायिक सिस्टम में, डेटाबेस प्रदर्शन एक महत्वपूर्ण कारक है जो सीधे समग्र प्रतिक्रिया समय को प्रभावित करता है। विशेष रूप से MySQL का उपयोग करते समय, “एक्जीक्यूशन प्लान” को समझना क्वेरी दक्षता का मूल्यांकन करने के लिए आवश्यक है। पारंपरिक EXPLAIN कमांड SQL स्टेटमेंट चलाने से पहले एक्जीक्यूशन प्लान दिखाता है और लंबे समय से डेवलपर्स को मूल्यवान अंतर्दृष्टि प्रदान करता आया है।

MySQL 8.0 में प्रस्तुत “EXPLAIN ANALYZE”

MySQL 8.0.18 में प्रस्तुत EXPLAIN ANALYZE पारंपरिक EXPLAIN का एक शक्तिशाली विस्तार है। जबकि EXPLAIN केवल “सैद्धांतिक प्लान” प्रदान करता था, EXPLAIN ANALYZE वास्तव में क्वेरी को चलाता है और एक्जीक्यूशन टाइम और प्रोसेस्ड रो काउंट जैसी मापी गई डेटा लौटाता है। यह बॉटलनेक की अधिक सटीक पहचान और क्वेरी अनुकूलन परिणामों की वैधता को संभव बनाता है।

EXPLAIN ANALYZE क्यों महत्वपूर्ण है

उदाहरण के लिए, JOIN क्रम, इंडेक्स उपयोग, और फ़िल्टरिंग शर्तें एक्जीक्यूशन टाइम को काफी प्रभावित करती हैं। EXPLAIN ANALYZE का उपयोग करके आप दृश्य रूप से देख सकते हैं कि कोई SQL स्टेटमेंट कैसे कार्य करता है और यह निर्धारित कर सकते हैं कि कहाँ अक्षमताएँ मौजूद हैं और क्या अनुकूलित किया जाना चाहिए। यह विशेष रूप से बड़े डेटा सेट या जटिल क्वेरीज़ के साथ काम करते समय अनिवार्य है।

इस लेख का उद्देश्य और लक्षित पाठक वर्ग

यह लेख MySQL के EXPLAIN ANALYZE की बुनियादी बातों से लेकर उसके आउटपुट की व्याख्या और व्यावहारिक अनुकूलन तकनीकों के अनुप्रयोग तक सब कुछ समझाता है। यह उन डेवलपर्स और इन्फ्रास्ट्रक्चर इंजीनियर्स के लिए है जो नियमित रूप से MySQL का उपयोग करते हैं, साथ ही उन इंजीनियर्स के लिए भी जो प्रदर्शन ट्यूनिंग में रुचि रखते हैं। शुरुआती लोगों के लिए स्पष्टता सुनिश्चित करने हेतु हम शब्दावली की व्याख्याएँ और ठोस उदाहरण शामिल करते हैं।

2. EXPLAIN और EXPLAIN ANALYZE के बीच अंतर

EXPLAIN की भूमिका और मूल उपयोग

MySQL का EXPLAIN एक विश्लेषण उपकरण है जो यह समझने में मदद करता है कि कोई SQL स्टेटमेंट (विशेषकर SELECT स्टेटमेंट) पहले से कैसे निष्पादित होगा। यह आपको इंडेक्स उपयोग, जॉइन क्रम, और सर्च रेंज जैसे एक्जीक्यूशन प्लान की पुष्टि करने की अनुमति देता है।

उदाहरण के लिए:

EXPLAIN SELECT * FROM users WHERE age > 30;

जब यह कमांड चलाया जाता है, MySQL वास्तव में क्वेरी नहीं चलाता, बल्कि टेबलर रूप में यह दिखाता है कि वह इसे कैसे प्रोसेस करने की योजना बना रहा है। आउटपुट में उपयोग किए गए इंडेक्स (key), एक्सेस मेथड (type), और अनुमानित पंक्तियों की संख्या (rows) जैसी जानकारी शामिल होती है।

EXPLAIN ANALYZE की भूमिका और विशेषताएँ

इसके विपरीत, MySQL 8.0.18 में प्रस्तुत EXPLAIN ANALYZE क्वेरी को चलाता है और वास्तविक मापी गई मानों के आधार पर एक्जीक्यूशन प्लान दिखाता है। यह पारंपरिक EXPLAIN में न दिखने वाले विवरणों की पुष्टि संभव बनाता है, जैसे वास्तविक प्रोसेसिंग टाइम और वास्तव में प्रोसेस की गई पंक्तियों की संख्या।

उदाहरण:

EXPLAIN ANALYZE SELECT * FROM users WHERE age > 30;

यह कमांड क्वेरी को चलाता है और निम्नलिखित आउटपुट लौटाता है:

  • प्लान के प्रत्येक चरण का एक्जीक्यूशन टाइम (उदा., 0.0022 sec)
  • पढ़ी गई वास्तविक पंक्तियों की संख्या (rows)
  • प्रोसेसिंग संरचना (TREE फ़ॉर्मेट का उपयोग करके आसानी से विज़ुअलाइज़ किया जा सकता है)

मुख्य अंतर का सारांश

ItemEXPLAINEXPLAIN ANALYZE
Query ExecutionDoes not executeExecutes the query
Information ProvidedEstimated information before executionMeasured information after execution
Primary UseChecking indexes and join orderActual performance analysis
MySQL VersionAvailable since early versionsMySQL 8.0.18 or later

आपको कौन सा उपयोग करना चाहिए?

  • जब आप जल्दी से क्वेरी संरचना की जाँच करना चाहते हैं, तो EXPLAIN का उपयोग करें।
  • जब आपको एक्जीक्यूशन टाइम और क्वेरी लागत के बारे में ठोस विवरण चाहिए, तो EXPLAIN ANALYZE का उपयोग करें।

विशेष रूप से प्रदर्शन ट्यूनिंग परिदृश्यों में, EXPLAIN ANALYZE वास्तविक निष्पादन डेटा के आधार पर अनुकूलन सक्षम करता है, न कि अनुमान पर, जिससे यह एक अत्यंत शक्तिशाली उपकरण बन जाता है।

3. EXPLAIN ANALYZE के आउटपुट फ़ॉर्मेट

तीन आउटपुट फ़ॉर्मेट: TRADITIONAL, JSON, और TREE

MySQL का EXPLAIN ANALYZE आपके उद्देश्य के अनुसार विभिन्न फ़ॉर्मेट में परिणाम दे सकता है। MySQL 8.0 और बाद के संस्करणों में निम्नलिखित तीन फ़ॉर्मेट उपलब्ध हैं।

FormatFeaturesEase of Use
TRADITIONALClassic table-style output. Familiar and easy to readBeginner-friendly
JSONProvides structured, detailed informationBest for tooling and integrations
TREEMakes nested structure visually clearIntermediate to advanced

आइए इन अंतर को करीब से देखें।

TRADITIONAL फ़ॉर्मेट (डिफ़ॉल्ट)

TRADITIONAL आउटपुट क्लासिक EXPLAIN शैली के समान है और आपको परिचित रूप में निष्पादन योजनाओं की समीक्षा करने देता है। यदि आप EXPLAIN ANALYZE को बिना किसी फ़ॉर्मेट को निर्दिष्ट किए चलाते हैं, तो परिणाम आमतौर पर इस फ़ॉर्मेट में दिखाया जाता है।

Example output (excerpt):

-> Filter: (age > 30)  (cost=0.35 rows=10) (actual time=0.002..0.004 rows=8 loops=1)
  • cost : अनुमानित लागत
  • actual time : मापी गई समय
  • rows : प्रोसेस की गई पंक्तियों की अनुमानित संख्या (एक्जीक्यूशन से पहले)
  • loops : लूप गिनती (विशेष रूप से JOIN के लिए महत्वपूर्ण)

TRADITIONAL फ़ॉर्मेट मनुष्यों के लिए स्कैन और समझना आसान है, जिससे यह शुरुआती और त्वरित जाँचों के लिए उपयुक्त बनता है।

JSON Format

JSON फ़ॉर्मेट अधिक विस्तृत है और प्रोग्रामेटिक रूप से संभालना आसान है। आउटपुट संरचित है, जहाँ प्रत्येक नोड को एक नेस्टेड ऑब्जेक्ट के रूप में दर्शाया जाता है।

Command:

EXPLAIN ANALYZE FORMAT=JSON SELECT * FROM users WHERE age > 30;

Part of the output (pretty-printed):

{
  "query_block": {
    "table": {
      "table_name": "users",
      "access_type": "range",
      "rows_examined_per_scan": 100,
      "actual_rows": 80,
      "filtered": 100,
      "cost_info": {
        "query_cost": "0.35"
      },
      "timing": {
        "start_time": 0.001,
        "end_time": 0.004
      }
    }
  }
}

यह फ़ॉर्मेट दृश्य रूप से कम पढ़ने योग्य है, लेकिन जब आप डेटा को पार्स करना चाहते हैं और उसे विश्लेषण टूल्स या डैशबोर्ड में फीड करना चाहते हैं तो यह अत्यंत सुविधाजनक है।

TREE Format (पढ़ने योग्य और संरचना को विज़ुअलाइज़ करने के लिए उत्कृष्ट)

TREE फ़ॉर्मेट क्वेरी निष्पादन संरचना को एक ट्री के रूप में प्रदर्शित करता है, जिससे JOIN और सबक्वेरी प्रोसेसिंग क्रम को समझना आसान हो जाता है।

Command:

EXPLAIN ANALYZE FORMAT=TREE SELECT * FROM users WHERE age > 30;

Example output (simplified):

-> Table scan on users  (actual time=0.002..0.004 rows=8 loops=1)

जटिल क्वेरीज़ के लिए, नेस्टिंग इस प्रकार दिख सकती है:

-> Nested loop join
    -> Table scan on users
    -> Index lookup on orders using idx_user_id

TREE फ़ॉर्मेट विशेष रूप से कई JOINs या जटिल नेस्टिंग वाली क्वेरीज़ के लिए उपयोगी है, जहाँ आपको प्रोसेसिंग फ्लो को समझना आवश्यक होता है।

Which Format Should You Use?

Use CaseRecommended Format
Beginner and want a simple viewTRADITIONAL
Want to analyze programmaticallyJSON
Want to understand structure and nestingTREE

ऐसा फ़ॉर्मेट चुनें जो आपके लक्ष्य के साथ सबसे बेहतर मेल खाता हो, और सबसे पढ़ने योग्य और विश्लेषण योग्य शैली में निष्पादन योजना की समीक्षा करें।

4. निष्पादन योजनाओं की व्याख्या कैसे करें

Why You Need to Read Execution Plans

MySQL क्वेरी प्रदर्शन डेटा की मात्रा और इंडेक्स की उपलब्धता पर बहुत अधिक निर्भर करता है। EXPLAIN ANALYZE से प्राप्त निष्पादन योजना आउटपुट की सही व्याख्या करके, आप वस्तुनिष्ठ रूप से पहचान सकते हैं कि कार्य कहाँ बर्बाद हो रहा है और क्या सुधारना चाहिए। यह कौशल प्रदर्शन ट्यूनिंग का मूलभूत हिस्सा है, विशेष रूप से उन क्वेरीज़ के लिए जो बड़े डेटासेट या जटिल जॉइन्स को संभालती हैं।

Basic Structure of an Execution Plan

EXPLAIN ANALYZE का आउटपुट निम्नलिखित जैसी जानकारी शामिल करता है (यहाँ TRADITIONAL-शैली के आउटपुट के आधार पर समझाया गया है):

-> Filter: (age > 30)  (cost=0.35 rows=10) (actual time=0.002..0.004 rows=8 loops=1)

यह एकल पंक्ति कई महत्वपूर्ण फ़ील्ड्स रखती है।

FieldDescription
FilterFiltering step for conditions such as WHERE clauses
costEstimated cost before execution
rowsEstimated number of processed rows (before execution)
actual timeMeasured elapsed time (start to end)
actual rowsActual number of processed rows
loopsHow many times this step was repeated (important for nested operations)

How to Read Key Fields

1. cost बनाम actual time

  • cost MySQL द्वारा गणना किया गया एक आंतरिक अनुमान है और इसे सापेक्ष मूल्यांकन के लिए उपयोग किया जाता है।
  • actual time वास्तविक बीता हुआ समय दर्शाता है और प्रदर्शन विश्लेषण के लिए अधिक महत्वपूर्ण है।

उदाहरण के लिए:

(cost=0.35 rows=100) (actual time=0.002..0.004 rows=100)

यदि अनुमान और माप निकटता से मेल खाते हैं, तो निष्पादन योजना संभवतः सटीक है। यदि अंतर बड़ा है, तो तालिका सांख्यिकी असटीक हो सकती है।

2. rows बनाम actual rows

  • rows वह पंक्तियों की संख्या है जो MySQL अनुमान लगाता है कि वह पढ़ेगा।
  • actual rows वास्तव में पढ़ी गई पंक्तियों की संख्या है (TRADITIONAL-शैली के आउटपुट में कोष्ठकों में शामिल)।

यदि बड़ा अंतर है, तो आपको सांख्यिकी को रीफ़्रेश करने या इंडेक्स डिज़ाइन पर पुनर्विचार करने की आवश्यकता हो सकती है।

3. loops

यदि loops=1, तो चरण एक बार चलता है। JOINs या सबक्वेरीज़ के साथ, आप loops=10 या loops=1000 देख सकते हैं। मान जितना बड़ा होगा, उतना ही अधिक संभावना है कि नेस्टेड लूप्स भारी प्रसंस्करण का कारण बन रहे हैं।

निष्पादन योजनाओं की नेस्टेड संरचना को समझें

जब कई तालिकाओं को जोड़ा जाता है, तो निष्पादन योजना को एक वृक्ष के रूप में दिखाया जाता है (विशेष रूप से TREE प्रारूप में स्पष्ट)।

उदाहरण:

-> Nested loop join
    -> Table scan on users
    -> Table scan on orders

समस्या

  • दोनों तालिकाओं को पूरी तरह से स्कैन किया जाता है, जिससे उच्च जोड़ लागत होती है।

उपाय

  • users.age पर एक इंडेक्स जोड़ें और पहले फ़िल्टर करें ताकि जोड़ कार्यभार कम हो।

प्रदर्शन बाधाओं की पहचान कैसे करें

निम्नलिखित बिंदुओं पर ध्यान केंद्रित करने से बाधाओं को ढूंढना आसान हो जाता है:

  • लंबे वास्तविक समय और कई पंक्तियों वाले नोड्स : ये निष्पादन समय का अधिकांश हिस्सा खपत करते हैं
  • पूर्ण तालिका स्कैन होने वाली जगहें : संभावित रूप से इंडेक्स गायब या अनुपयोगी
  • कई लूप्स वाले चरण : अक्षम JOIN क्रम या नेस्टिंग का संकेत
  • पंक्तियों और वास्तविक पंक्तियों के बीच बड़े अंतर : अशुद्ध सांख्यिकी या अत्यधिक डेटा पहुंच का सुझाव

इन अंतर्दृष्टियों को अगले अनुभाग में पेश की गई “क्वेरी अनुकूलन” तकनीकों की नींव के रूप में उपयोग करें।

5. व्यावहारिक क्वेरी अनुकूलन उदाहरण

क्वेरी अनुकूलन क्या है?

क्वेरी अनुकूलन का अर्थ है SQL स्टेटमेंट्स की समीक्षा और सुधार करना ताकि वे अधिक कुशलता से निष्पादित हो सकें। MySQL द्वारा क्वेरीज़ को आंतरिक रूप से कैसे संसाधित किया जाता है (निष्पादन योजनाओं) के आधार पर, आप इंडेक्स जोड़ना, JOIN क्रम समायोजित करना, और अनावश्यक प्रसंस्करण को समाप्त करना जैसे सुधार लागू करते हैं।

यहां, हम EXPLAIN ANALYZE का उपयोग करके क्वेरीज़ को कैसे सुधारें, इसके ठोस उदाहरणों से प्रदर्शित करते हैं।

उदाहरण 1: इंडेक्स का उपयोग करके गति सुधार

अनुकूलन से पहले

SELECT * FROM users WHERE email = 'example@example.com';

निष्पादन योजना (अंश)

-> Table scan on users  (cost=10.5 rows=100000) (actual time=0.001..0.230 rows=1 loops=1)

समस्या

  • आउटपुट में Table scan दिखाया गया है, जिसका अर्थ है कि पूर्ण तालिका स्कैन किया जाता है। बड़े डेटासेट के साथ, यह महत्वपूर्ण विलंब का कारण बनता है।

समाधान: एक इंडेक्स जोड़ें

CREATE INDEX idx_email ON users(email);

अनुकूलन के बाद निष्पादन योजना

-> Index lookup on users using idx_email  (cost=0.1 rows=1) (actual time=0.001..0.002 rows=1 loops=1)

परिणाम

  • निष्पादन समय काफी कम हो गया।
  • इंडेक्स का उपयोग करके पूर्ण तालिका स्कैन से बचा गया।

उदाहरण 2: JOIN क्रम का अनुकूलन

अनुकूलन से पहले

SELECT * FROM orders
JOIN users ON orders.user_id = users.id
WHERE users.age > 30;

निष्पादन योजना (अंश)

-> Nested loop join
    -> Table scan on orders
    -> Table scan on users

समस्या

  • दोनों तालिकाओं को पूरी तरह से स्कैन किया जाता है, जिससे उच्च जोड़ लागत होती है।

समाधान

  • users.age पर एक इंडेक्स जोड़ें और पहले फ़िल्टर करें ताकि JOIN लक्ष्य आकार कम हो।
    CREATE INDEX idx_age ON users(age);
    

अनुकूलन के बाद निष्पादन योजना

-> Nested loop join
    -> Index range scan on users using idx_age
    -> Index lookup on orders using idx_user_id

परिणाम

  • JOIN लक्ष्यों को पहले फ़िल्टर किया जाता है, जिससे समग्र प्रसंस्करण भार कम होता है।

उदाहरण 3: सबक्वेरी का संशोधन

अनुकूलन से पहले

SELECT * FROM users WHERE id IN (SELECT user_id FROM orders WHERE total > 1000);

समस्या

  • सबक्वेरी को बार-बार मूल्यांकित किया जा सकता है, जिससे प्रदर्शन खराब होता है।

समाधान: JOIN के रूप में पुनर्लेखन

SELECT DISTINCT users.*
FROM users
JOIN orders ON users.id = orders.user_id
WHERE orders.total > 1000;

परिणाम

  • निष्पादन योजना JOIN प्रसंस्करण के लिए अनुकूलित है, और इंडेक्स का उपयोग होने की अधिक संभावना है।

पहले/बाद की तुलना का महत्व

Using EXPLAIN ANALYZE, you can verify optimization results with actual measured values. By comparing execution time and row counts before and after improvements, you ensure that tuning efforts are based on real performance gains rather than assumptions.

अनुकूलन में महत्वपूर्ण विचार

  • बहुत अधिक इंडेक्स जोड़ना प्रतिकूल हो सकता है (INSERT/UPDATE प्रदर्शन धीमा हो जाता है)।
  • एक्जीक्यूशन प्लान डेटा मात्रा और आँकड़ों पर निर्भर करते हैं, इसलिए प्रत्येक वातावरण में वैधता आवश्यक है।
  • एक अनुकूलन शायद ही कभी सब कुछ हल करता है। बॉटलनेक विश्लेषण पहले आता है

6. सावधानियां और सर्वोत्तम प्रथाएँ

EXPLAIN ANALYZE का उपयोग करते समय महत्वपूर्ण नोट्स

हालांकि EXPLAIN ANALYZE अत्यंत शक्तिशाली है, अनुचित उपयोग से गलतफहमी या यहां तक कि संचालन जोखिम हो सकते हैं। निम्नलिखित बिंदुओं को ध्यान में रखने से सुरक्षित और प्रभावी क्वेरी विश्लेषण सुनिश्चित होता है।

1. प्रोडक्शन में लापरवाही से चलाने से बचें

क्योंकि EXPLAIN ANALYZE वास्तव में क्वेरी को निष्पादित करता है, संशोधन कथनों (INSERT/UPDATE/DELETE) के साथ गलती से उपयोग करने से डेटा बदल सकता है।

  • सामान्यतः, इसे केवल SELECT कथनों के साथ उपयोग करें।
  • प्रोडक्शन के बजाय स्टेजिंग या परीक्षण वातावरण में चलाने को प्राथमिकता दें

2. कैशिंग के प्रभाव पर विचार करें

यदि समान क्वेरी बार-बार चलायी जाती है तो MySQL कैश से परिणाम लौटा सकता है। परिणामस्वरूप, EXPLAIN ANALYZE द्वारा रिपोर्ट किया गया निष्पादन समय वास्तविक व्यवहार से भिन्न हो सकता है।

उपाय:

  • निष्पादन से पहले कैश साफ़ करें ( RESET QUERY CACHE; )।
  • कई बार चलाएँ और औसत मानों के आधार पर मूल्यांकन करें।

3. आँकड़े अद्यतित रखें

MySQL तालिका और इंडेक्स आँकड़ों के आधार पर निष्पादन योजनाएँ बनाता है। यदि आँकड़े पुराने हैं, तो EXPLAIN और EXPLAIN ANALYZE दोनों भ्रामक जानकारी दे सकते हैं।

बड़े INSERT या DELETE ऑपरेशनों के बाद, ANALYZE TABLE का उपयोग करके आँकड़े अपडेट करें

ANALYZE TABLE users;

4. इंडेक्स जादुई समाधान नहीं हैं

इंडेक्स अक्सर प्रदर्शन सुधारते हैं, लेकिन बहुत अधिक इंडेक्स लिखने के ऑपरेशनों को धीमा कर देते हैं

कॉम्पोज़िट इंडेक्स और सिंगल-कलम इंडेक्स के बीच चयन भी महत्वपूर्ण है। क्वेरी पैटर्न और उपयोग की आवृत्ति के आधार पर इंडेक्स को सावधानीपूर्वक डिज़ाइन करें।

5. केवल निष्पादन समय से निर्णय न लें

EXPLAIN ANALYZE के परिणाम केवल एकल क्वेरी के प्रदर्शन को दर्शाते हैं। वास्तविक अनुप्रयोगों में, नेटवर्क लेटेंसी या बैकएंड प्रोसेसिंग वास्तविक बॉटलनेक हो सकता है।

इसलिए, पूरे सिस्टम आर्किटेक्चर के संदर्भ में क्वेरी का विश्लेषण करें

सर्वोत्तम प्रथाओं का सारांश

Key PointRecommended Action
Production safetyUse only with SELECT statements; avoid modification queries
Cache handlingClear cache before testing; use averaged measurements
Statistics maintenanceRegularly update statistics with ANALYZE TABLE
Balanced index designMinimize unnecessary indexes; consider read/write balance
Avoid tunnel visionOptimize within the context of the entire application

7. अक्सर पूछे जाने वाले प्रश्न (FAQ)

प्रश्न 1. EXPLAIN ANALYZE किस संस्करण से उपलब्ध है?

A.
MySQL का EXPLAIN ANALYZE संस्करण 8.0.18 और बाद के में पेश किया गया था। यह 8.0 से पहले के संस्करणों में समर्थित नहीं है, इसलिए उपयोग करने से पहले अपने MySQL संस्करण की पुष्टि करें।

प्रश्न 2. क्या EXPLAIN ANALYZE चलाने से डेटा बदल सकता है?

A.
EXPLAIN ANALYZE क्वेरी को आंतरिक रूप से निष्पादित करता है।
जब SELECT कथन के साथ उपयोग किया जाता है, तो यह डेटा नहीं बदलता।

इसलिए, जब SELECT कथन के साथ उपयोग किया जाता है, तो यह डेटा नहीं बदलता

हालांकि, यदि आप इसे गलती से INSERT, UPDATE, या DELETE के साथ उपयोग करते हैं, तो डेटा सामान्य क्वेरी की तरह बदल जाएगा।

सुरक्षा के लिए, प्रोडक्शन के बजाय परीक्षण या स्टेजिंग डेटाबेस में विश्लेषण चलाने की सिफारिश की जाती है।

प्रश्न 3. क्या केवल EXPLAIN पर्याप्त नहीं है?

A.
EXPLAIN “अनुमानित” निष्पादन योजना की समीक्षा के लिए पर्याप्त है। हालांकि, यह वास्तविक निष्पादन समय या वास्तविक पंक्ति गिनती जैसे मापे गए मान प्रदान नहीं करता।

यदि आपको गंभीर क्वेरी ट्यूनिंग की आवश्यकता है या अनुकूलन प्रभावों की पुष्टि करना चाहते हैं, तो EXPLAIN ANALYZE अधिक उपयोगी है।

प्रश्न 4. “loops” और “actual time” जैसे मान कितने सटीक होते हैं?

A.
actual time और loops जैसे मान MySQL द्वारा आंतरिक रूप से मापे गए वास्तविक निष्पादन मीट्रिक हैं। हालांकि, ये OS स्थितियों, कैश स्थिति, और सर्वर लोड के आधार पर थोड़ा बदल सकते हैं।

For this reason, do not rely on a single measurement. Instead, run the query multiple times and evaluate trends.

Q5. “cost” वास्तव में क्या दर्शाता है?

A.
cost MySQL के आंतरिक लागत मॉडल द्वारा गणना किया गया एक अनुमानित मान है। यह CPU और I/O लागतों के सापेक्ष मूल्यांकन को दर्शाता है। इसे सेकंड में व्यक्त नहीं किया जाता है।

उदाहरण के लिए, यदि आप (cost=0.3) और (cost=2.5) देखते हैं, तो बाद वाला सापेक्ष रूप से अधिक महंगा माना जाता है।

Q6. JSON या TREE फ़ॉर्मेट का उपयोग करने के क्या लाभ हैं?

A.

  • JSON फ़ॉर्मेट : संरचित आउटपुट जो प्रोग्रामेटिक रूप से पार्स करना आसान है। ऑटोमेशन टूल्स और डैशबोर्ड के लिए उपयोगी।
  • TREE फ़ॉर्मेट : निष्पादन प्रवाह और नेस्टिंग को दृश्य रूप से स्पष्ट बनाता है। जटिल क्वेरीज़ और JOIN क्रम को समझने के लिए आदर्श।

अपने उद्देश्य के अनुसार सबसे उपयुक्त फ़ॉर्मेट चुनें।

Q7. निष्पादन योजना की समीक्षा करने के बाद यदि मैं प्रदर्शन सुधार नहीं सकता तो मुझे क्या करना चाहिए?

A.
निम्नलिखित अतिरिक्त उपायों पर विचार करें:

  • इंडेक्स का पुनः डिज़ाइन (संयुक्त इंडेक्स या कवरेज इंडेक्स)
  • क्वेरीज़ को पुनर्लेखन (सबक्वेरी → JOIN, अनावश्यक SELECT कॉलम हटाना)
  • व्यूज़ या टेम्पररी टेबल्स का उपयोग
  • MySQL कॉन्फ़िगरेशन की समीक्षा (बफ़र आकार, मेमोरी आवंटन, आदि)

प्रदर्शन ट्यूनिंग अक्सर एक ही तकनीक से सफल नहीं होती। एक व्यापक और क्रमिक दृष्टिकोण आवश्यक है।