जब आपको लगा कि यह सुरक्षित है ...
आपका क्या मूल्य है eq_range_index_dive_limit
? विशेष रूप से, क्या आपके पास IN
खंड में कम या ज्यादा आइटम हैं ?
इसमें एक बेंचमार्क शामिल नहीं होगा, लेकिन आंतरिक कामकाज में थोड़ा सहयोग करेगा। चलिए देखते हैं कि क्या चल रहा है - ऑप्टिमाइज़र ट्रेस।
पूछताछ: SELECT * FROM canada WHERE id ...
एक साथ OR
3 मूल्यों की , का पता लगाने के हिस्से की तरह दिखता है:
"condition_processing": {
"condition": "WHERE",
"original_condition": "((`canada`.`id` = 296172) or (`canada`.`id` = 295093) or (`canada`.`id` = 293626))",
"steps": [
{
"transformation": "equality_propagation",
"resulting_condition": "(multiple equal(296172, `canada`.`id`) or multiple equal(295093, `canada`.`id`) or multiple equal(293626, `canada`.`id`))"
},
...
"analyzing_range_alternatives": {
"range_scan_alternatives": [
{
"index": "id",
"ranges": [
"293626 <= id <= 293626",
"295093 <= id <= 295093",
"296172 <= id <= 296172"
],
"index_dives_for_eq_ranges": true,
"chosen": true
...
"refine_plan": [
{
"table": "`canada`",
"pushed_index_condition": "((`canada`.`id` = 296172) or (`canada`.`id` = 295093) or (`canada`.`id` = 293626))",
"table_condition_attached": null,
"access_type": "range"
}
]
ध्यान दें कि ICP कैसे दिया जा रहा है ORs
। इसका तात्पर्य यह है कि OR
इसे चालू नहीं किया गया है IN
, और InnoDB का एक गुच्छा प्रदर्शन किया जाएगा=
ICP के माध्यम परीक्षणों । (मुझे नहीं लगता कि यह MyISAM पर विचार करने लायक है।)
(यह पेरकोना का 5.6.22-71.0-लॉग है; id
एक माध्यमिक सूचकांक है।)
अब कुछ मूल्यों के साथ IN () के लिए
eq_range_index_dive_limit
= 10; 8 मान हैं।
"condition_processing": {
"condition": "WHERE",
"original_condition": "(`canada`.`id` in (296172,295093,293626,295573,297148,296127,295588,295810))",
"steps": [
{
"transformation": "equality_propagation",
"resulting_condition": "(`canada`.`id` in (296172,295093,293626,295573,297148,296127,295588,295810))"
},
...
"analyzing_range_alternatives": {
"range_scan_alternatives": [
{
"index": "id",
"ranges": [
"293626 <= id <= 293626",
"295093 <= id <= 295093",
"295573 <= id <= 295573",
"295588 <= id <= 295588",
"295810 <= id <= 295810",
"296127 <= id <= 296127",
"296172 <= id <= 296172",
"297148 <= id <= 297148"
],
"index_dives_for_eq_ranges": true,
"chosen": true
...
"refine_plan": [
{
"table": "`canada`",
"pushed_index_condition": "(`canada`.`id` in (296172,295093,293626,295573,297148,296127,295588,295810))",
"table_condition_attached": null,
"access_type": "range"
}
]
ध्यान दें कि IN
यह नहीं लगता है OR
।
एक साइड नोट: ध्यान दें कि निरंतर मानों को क्रमबद्ध किया गया था । यह दो तरह से फायदेमंद हो सकता है:
- कम कूदने से, सभी मूल्यों को प्राप्त करने के लिए बेहतर कैशिंग, कम I / O हो सकता है।
- यदि दो समान प्रश्न अलग-अलग कनेक्शन से आ रहे हैं, और वे लेनदेन में हैं, तो ओवरलैपिंग सूचियों के कारण गतिरोध के बजाय देरी होने की बेहतर संभावना है।
अंत में, () बहुत सारे मूल्यों के साथ
{
"condition_processing": {
"condition": "WHERE",
"original_condition": "(`canada`.`id` in (293831,292259,292881,293440,292558,295792,292293,292593,294337,295430,295034,297060,293811,295587,294651,295559,293213,295742,292605,296018,294529,296711,293919,294732,294689,295540,293000,296916,294433,297112,293815,292522,296816,293320,293232,295369,291894,293700,291839,293049,292738,294895,294473,294023,294173,293019,291976,294923,294797,296958,294075,293450,296952,297185,295351,295736,296312,294330,292717,294638,294713,297176,295896,295137,296573,292236,294966,296642,296073,295903,293057,294628,292639,293803,294470,295353,297196,291752,296118,296964,296185,295338,295956,296064,295039,297201,297136,295206,295986,292172,294803,294480,294706,296975,296604,294493,293181,292526,293354,292374,292344,293744,294165,295082,296203,291918,295211,294289,294877,293120,295387))",
"steps": [
{
"transformation": "equality_propagation",
"resulting_condition": "(`canada`.`id` in (293831,292259,292881,293440,292558,295792,292293,292593,294337,295430,295034,297060,293811,295587,294651,295559,293213,295742,292605,296018,294529,296711,293919,294732,294689,295540,293000,296916,294433,297112,293815,292522,296816,293320,293232,295369,291894,293700,291839,293049,292738,294895,294473,294023,294173,293019,291976,294923,294797,296958,294075,293450,296952,297185,295351,295736,296312,294330,292717,294638,294713,297176,295896,295137,296573,292236,294966,296642,296073,295903,293057,294628,292639,293803,294470,295353,297196,291752,296118,296964,296185,295338,295956,296064,295039,297201,297136,295206,295986,292172,294803,294480,294706,296975,296604,294493,293181,292526,293354,292374,292344,293744,294165,295082,296203,291918,295211,294289,294877,293120,295387))"
},
...
"analyzing_range_alternatives": {
"range_scan_alternatives": [
{
"index": "id",
"ranges": [
"291752 <= id <= 291752",
"291839 <= id <= 291839",
...
"297196 <= id <= 297196",
"297201 <= id <= 297201"
],
"index_dives_for_eq_ranges": false,
"rows": 111,
"chosen": true
...
"refine_plan": [
{
"table": "`canada`",
"pushed_index_condition": "(`canada`.`id` in (293831,292259,292881,293440,292558,295792,292293,292593,294337,295430,295034,297060,293811,295587,294651,295559,293213,295742,292605,296018,294529,296711,293919,294732,294689,295540,293000,296916,294433,297112,293815,292522,296816,293320,293232,295369,291894,293700,291839,293049,292738,294895,294473,294023,294173,293019,291976,294923,294797,296958,294075,293450,296952,297185,295351,295736,296312,294330,292717,294638,294713,297176,295896,295137,296573,292236,294966,296642,296073,295903,293057,294628,292639,293803,294470,295353,297196,291752,296118,296964,296185,295338,295956,296064,295039,297201,297136,295206,295986,292172,294803,294480,294706,296975,296604,294493,293181,292526,293354,292374,292344,293744,294165,295082,296203,291918,295211,294289,294877,293120,295387))",
"table_condition_attached": null,
"access_type": "range"
}
]
साइड नोट: मुझे ट्रेस की भारीता के कारण इसकी आवश्यकता थी:
@@global.optimizer_trace_max_mem_size = 32222;
s I could say that it can also be converted to UNION
जिसे क्वेरी को ऑप्टिमाइज़ करने के लिए ORA को प्रतिस्थापित करने के लिए पुन: बनाया गया है।