delete_option

Удаляет настройки (запись из таблицы wp_options в БД).

Эта функция создана для безопасного удаление записей (настроек) из Базы Данных.

Хуки из функции:
deleted_option
delete_option
delete_option_(option)
Возвращает

true/false. true, если настройка была найдена и удалена и false, в противном случае.

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

delete_option( $name );
$name(строка) (обязательный)
Название опции, которую нужно удалить.
По умолчанию: нет

Примеры

#1. Пример обычного использования. Удалим опцию myoption

<?php delete_option('myoption'); ?>

#2. Удалим сразу несколько опций и убедимся что они удалились

Тут мы попытаемся удалить следующие опции: is_installed, my_plugin_version, my_option.

<?php
function deleteOptions()
{
	$args = func_get_args();
	$num = count($args);

	if ($num == 1) {
		return (delete_option($args[0]) ? TRUE : FALSE);
	}
	elseif ($num > 1)
	{
		foreach ($args as $option) {
			if ( ! delete_option($option))
				return FALSE;
		}
		return TRUE;
	}
	return FALSE;
}

if( deleteOptions('is_installed', 'my_plugin_version', 'my_option') )
   echo 'Настройки были удалены!';
else
   echo 'Удаление настроек вызвало ошибку. Настройки удалить не удалось!';
?>

Код из


wp-includes/option.php

WP 4.7.3

<?php
function delete_option( $option ) {
	global $wpdb;

	$option = trim( $option );
	if ( empty( $option ) )
		return false;

	wp_protect_special_option( $option );

	// Get the ID, if no ID then return
	$row = $wpdb->get_row( $wpdb->prepare( "SELECT autoload FROM $wpdb->options WHERE option_name = %s", $option ) );
	if ( is_null( $row ) )
		return false;

	/**
	 * Fires immediately before an option is deleted.
	 *
	 * @since 2.9.0
	 *
	 * @param string $option Name of the option to delete.
	 */
	do_action( 'delete_option', $option );

	$result = $wpdb->delete( $wpdb->options, array( 'option_name' => $option ) );
	if ( ! wp_installing() ) {
		if ( 'yes' == $row->autoload ) {
			$alloptions = wp_load_alloptions();
			if ( is_array( $alloptions ) && isset( $alloptions[$option] ) ) {
				unset( $alloptions[$option] );
				wp_cache_set( 'alloptions', $alloptions, 'options' );
			}
		} else {
			wp_cache_delete( $option, 'options' );
		}
	}
	if ( $result ) {

		/**
		 * Fires after a specific option has been deleted.
		 *
		 * The dynamic portion of the hook name, `$option`, refers to the option name.
		 *
		 * @since 3.0.0
		 *
		 * @param string $option Name of the deleted option.
		 */
		do_action( "delete_option_{$option}", $option );

		/**
		 * Fires after an option has been deleted.
		 *
		 * @since 2.9.0
		 *
		 * @param string $option Name of the deleted option.
		 */
		do_action( 'deleted_option', $option );
		return true;
	}
	return false;
}

Комментарии:


Оставить комментарий

Your email address will not be published. Required fields are marked *