clean_user_cache()WP 3.0.0

Очищает весь кэш указанного пользователя.

Работает на основе: wp_cache_delete()
1 раз — 0.000052 сек (очень быстро) | 50000 раз — 8 сек (быстро) | PHP 7.0.2, WP 4.4.2
Хуки из функции

Возвращает

null. Ничего. Всегда NULL.

Использование

clean_user_cache( $user );
$user(WP_User/число) (обязательный)
ID или объект пользователя, кэш которого нужно полностью очистить.

Примеры

0

#1 Очистка кэша пользователя

Допустим мы обновляем пользователя и в процессе обновления мы изменил его данные, например отдельным запросом в БД. Теперь текущие данные могут не совпадать с темы что мы получим из кэша с помощью get_userdata() или с теми что находятся в глобальной переменной $current_user.

Чтобы обновить все эти данные нужно полностью очистить кэш пользователя:

$user_id = 12;
clean_user_cache( $user_id );

Список изменений

С версии 3.0.0 Введена.
С версии 4.4.0 clean_user_cache was added.
С версии 6.2.0 User metadata caches are now cleared.

Код clean_user_cache() WP 6.4.3

function clean_user_cache( $user ) {
	if ( is_numeric( $user ) ) {
		$user = new WP_User( $user );
	}

	if ( ! $user->exists() ) {
		return;
	}

	wp_cache_delete( $user->ID, 'users' );
	wp_cache_delete( $user->user_login, 'userlogins' );
	wp_cache_delete( $user->user_nicename, 'userslugs' );

	if ( ! empty( $user->user_email ) ) {
		wp_cache_delete( $user->user_email, 'useremail' );
	}

	wp_cache_delete( $user->ID, 'user_meta' );
	wp_cache_set_users_last_changed();

	/**
	 * Fires immediately after the given user's cache is cleaned.
	 *
	 * @since 4.4.0
	 *
	 * @param int     $user_id User ID.
	 * @param WP_User $user    User object.
	 */
	do_action( 'clean_user_cache', $user->ID, $user );
}