wp_load_core_site_options

函数
wp_load_core_site_options ( $network_id = null )
参数
  • (int) $network_id Optional site ID for which to query the options. Defaults to the current site.
    Required:
    Default: null
定义位置
相关方法
update_site_optionwp_load_alloptionsadd_site_optiondelete_site_optionget_site_option
引入
3.0.0
弃用
-

wp_load_core_site_options: 这个函数检索核心网站选项(如网站名称和标语)并将其缓存在内存中。它在WordPress的初始化过程中被调用。

如果is_multisite()和持久性缓存没有被使用,加载和缓存某些经常被请求的站点选项。

function wp_load_core_site_options( $network_id = null ) {
	global $wpdb;

	if ( ! is_multisite() || wp_using_ext_object_cache() || wp_installing() ) {
		return;
	}

	if ( empty( $network_id ) ) {
		$network_id = get_current_network_id();
	}

	$core_options = array( 'site_name', 'siteurl', 'active_sitewide_plugins', '_site_transient_timeout_theme_roots', '_site_transient_theme_roots', 'site_admins', 'can_compress_scripts', 'global_terms_enabled', 'ms_files_rewriting' );

	$core_options_in = "'" . implode( "', '", $core_options ) . "'";
	$options         = $wpdb->get_results( $wpdb->prepare( "SELECT meta_key, meta_value FROM $wpdb->sitemeta WHERE meta_key IN ($core_options_in) AND site_id = %d", $network_id ) );

	$data = array();
	foreach ( $options as $option ) {
		$key                = $option->meta_key;
		$cache_key          = "{$network_id}:$key";
		$option->meta_value = maybe_unserialize( $option->meta_value );

		$data[ $cache_key ] = $option->meta_value;
	}
	wp_cache_set_multiple( $data, 'site-options' );
}

常见问题

FAQs
查看更多 >