From a741e0d35092a07d734c2777d9fb55b885857eb1 Mon Sep 17 00:00:00 2001 From: markjaquith Date: Thu, 25 Jan 2007 00:12:08 +0000 Subject: [PATCH] Cache the non-existence of options to prevent redundant queries. props davidhouse. fixes #2268 git-svn-id: http://svn.automattic.com/wordpress/trunk@4798 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- wp-includes/functions.php | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/wp-includes/functions.php b/wp-includes/functions.php index 077873b7b2..062a2de765 100644 --- a/wp-includes/functions.php +++ b/wp-includes/functions.php @@ -203,6 +203,10 @@ function is_serialized_string($data) { function get_option($setting) { global $wpdb; + // prevent non-existent options from triggering multiple queries + if ( true === wp_cache_get($setting, 'notoptions') ) + return false; + $value = wp_cache_get($setting, 'options'); if ( false === $value ) { @@ -215,7 +219,8 @@ function get_option($setting) { if( is_object( $row) ) { // Has to be get_row instead of get_var because of funkiness with 0, false, null values $value = $row->option_value; wp_cache_set($setting, $value, 'options'); - } else { + } else { // option does not exist, so we must cache its non-existence + wp_cache_set($setting, true, 'notoptions'); return false; } } @@ -274,6 +279,9 @@ function update_option($option_name, $newvalue) { return true; } + if ( true === wp_cache_get($option_name, 'notoptions') ) + wp_cache_delete($option_name, 'notoptions'); + $_newvalue = $newvalue; $newvalue = maybe_serialize($newvalue);