जब संदेह हो, तो स्रोत कोड देखें।
में खुदाई get_option()
, आप देखेंगे (संक्षिप्त):
$value = wp_cache_get( $option, 'options' );
if ( false === $value ) {
$row = $wpdb->get_row( $wpdb->prepare( "SELECT option_value FROM $wpdb->options WHERE option_name = %s LIMIT 1", $option ) );
// Has to be get_row instead of get_var because of funkiness with 0, false, null values
if ( is_object( $row ) ) {
$value = $row->option_value;
wp_cache_add( $option, $value, 'options' );
} else { // option does not exist, so we must cache its non-existence
$notoptions[$option] = true;
wp_cache_set( 'notoptions', $notoptions, 'options' );
return apply_filters( 'default_option_' . $option, $default );
}
}
सबसे पहले, वर्डप्रेस यह देखने के लिए जांचता है कि क्या उसके पास पहले से ही मेमोरी में विकल्प है। डिफ़ॉल्ट रूप से, wp_cache_get()
इन-मेमोरी डेटा स्टोर (आमतौर पर सिर्फ एक PHP चर) से मूल्यों को पुनः प्राप्त करेगा। लेकिन कुछ इंस्टॉलेशन एक अधिक उन्नत ऑब्जेक्ट कैश का उपयोग करते हैं जो डेटा को कहीं और संग्रहीत करता है।
किसी भी स्थिति में, wp_cache_get()
यदि आपका वर्डप्रेस पहले से ही जानता है तो आपके विकल्प का मूल्य वापस कर देगा।
यदि नहीं, तो वर्डप्रेस डेटाबेस से इसे हथियाने की कोशिश करेगा। यदि विकल्प DB में मौजूद है, तो वर्डप्रेस इसे मेमोरी में कैश करेगा और फिर इसे वापस दे देगा - बाद के लुकअप को तेजी से बना देगा।
यदि विकल्प डेटाबेस में मौजूद नहीं है, तो वर्डप्रेस इसे एक आंतरिक "इन विकल्पों में मौजूद नहीं है" सरणी में फ़्लैग करता है, इसलिए यह इसे बाद में देखने की कोशिश नहीं करता है और इसके बजाय कुछ डिफ़ॉल्ट मान देता है।
तो, अपने मूल प्रश्न का उत्तर देने के लिए:
यदि मैं अपने प्लगइन के विभिन्न कार्यों में 10 बार उपयोग करता हूं, तो क्या वर्डप्रेस डेटाबेस में 10 प्रश्न करता है, या क्या यह केवल 1 डेटाबेस कॉल प्रति HTTP अनुरोध करता है और परिणामों को कैश करता है?
वर्डप्रेस 1 HTTP कॉल प्रति HTTP अनुरोध करेगा और परिणामों को कैश करेगा।