Удалить пост, если существует, по заголовку

Вопрос или проблема

Я хочу удалить пост из PHP по заголовку.

У меня есть код для публикации или обновления, если пост существует по заголовку, но я не знаю, как вставить функцию wp_delete_post().

Это мой текущий код для публикации или обновления, если пост существует по заголовку:

<?php
// требуется wp-load.php для использования встроенных функций WordPress
require_once("/var/www/mysite.com/wp-load.php");

//Заголовок
    $TítleProduct = ("Title Product 1");
//Описание
    $Desc = ("Product descripction 1");

// Регистрация данных поста

$post = array();
$post['post_status']   = 'publish';
$post['post_type']     = 'post'; // может быть и CPT
$post['post_title']    = "$TítleProduct";
$post['post_content']  = ($Desc);
$post['post_author']   = 1;

    function wp_exist_post_by_title($title)
    {
        global $wpdb;
        $return_id = $wpdb->get_row("SELECT ID FROM wp_posts WHERE post_title="" . $title . "" && post_type="post" ", 'ARRAY_N');
        if (empty($return_id)) {
            return false;
        } else {
            return $return_id;
        }
    }

    $id = wp_exist_post_by_title($post['post_title']);

    if($id !== false)
    {
        $post['ID'] = $id["0"];
        $post_id = wp_update_post( $post );
    } else {
        $post['post_date']     = $my_post['post_date'];
        $post_id = wp_insert_post( $post );
    }

/*******************************************************
** ПРОСТАЯ ПРОВЕРКА ОШИБОК
*******************************************************/

$finaltext="";

if($post_id){

$finaltext .= 'Пост '.$post['ID'].' был успешно создан/обновлён.<br>';

} else{

$finaltext .= 'Что-то пошло не так, и я не вставил новый пост.<br>';

}

echo $finaltext;
?>

Я пытался заменить wp_update_post на wp_delete_post и комбинировать с функцией wp_delete_post, но не знаю, как именно это сочетать, вот пример кода функции wp_delete_post:

function wp_delete_post( $postid = 0, $force_delete = false ) {
    global $wpdb;

    $post = $wpdb->get_row( $wpdb->prepare( "SELECT * FROM $wpdb->posts WHERE ID = %d", $postid ) );

    if ( ! $post ) {
        return $post;
    }

    $post = get_post( $post );

    if ( ! $force_delete && ( 'post' === $post->post_type || 'page' === $post->post_type ) && 'trash' !== get_post_status( $postid ) && EMPTY_TRASH_DAYS ) {
        return wp_trash_post( $postid );
    }

    if ( 'attachment' === $post->post_type ) {
        return wp_delete_attachment( $postid, $force_delete );
    }

    /**
     * Фильтры, определяющие, должно ли произойти удаление поста.
     *
     * @since 4.4.0
     *
     * @param bool|null $delete       Нужно ли продолжать удаление.
     * @param WP_Post   $post         Объект поста.
     * @param bool      $force_delete Нужно ли обойти Корзину.
     */
    $check = apply_filters( 'pre_delete_post', null, $post, $force_delete );
    if ( null !== $check ) {
        return $check;
    }

    /**
     * Срабатывает перед тем, как пост будет удалён, в начале wp_delete_post().
     *
     * @since 3.2.0
     * @since 5.5.0 Добавлен параметр `$post`.
     *
     * @see wp_delete_post()
     *
     * @param int     $postid ID поста.
     * @param WP_Post $post   Объект поста.
     */
    do_action( 'before_delete_post', $postid, $post );

    delete_post_meta( $postid, '_wp_trash_meta_status' );
    delete_post_meta( $postid, '_wp_trash_meta_time' );

    wp_delete_object_term_relationships( $postid, get_object_taxonomies( $post->post_type ) );

    $parent_data  = array( 'post_parent' => $post->post_parent );
    $parent_where = array( 'post_parent' => $postid );

    if ( is_post_type_hierarchical( $post->post_type ) ) {
        // Указывает дочерние элементы этой страницы на её родителя, также очищает кэш затронутых детей.
        $children_query = $wpdb->prepare( "SELECT * FROM $wpdb->posts WHERE post_parent = %d AND post_type = %s", $postid, $post->post_type );
        $children       = $wpdb->get_results( $children_query );
        if ( $children ) {
            $wpdb->update( $wpdb->posts, $parent_data, $parent_where + array( 'post_type' => $post->post_type ) );
        }
    }

    // Выполняет необработанный запрос. wp_get_post_revisions() фильтруется.
    $revision_ids = $wpdb->get_col( $wpdb->prepare( "SELECT ID FROM $wpdb->posts WHERE post_parent = %d AND post_type="revision"", $postid ) );
    // Использует wp_delete_post (через wp_delete_post_revision) снова. Обеспечивает удаление любых метаданных/неправильно расположенных данных.
    foreach ( $revision_ids as $revision_id ) {
        wp_delete_post_revision( $revision_id );
    }

    // Указывает все вложения этому посту на один уровень выше.
    $wpdb->update( $wpdb->posts, $parent_data, $parent_where + array( 'post_type' => 'attachment' ) );

    wp_defer_comment_counting( true );

    $comment_ids = $wpdb->get_col( $wpdb->prepare( "SELECT comment_ID FROM $wpdb->comments WHERE comment_post_ID = %d", $postid ) );
    foreach ( $comment_ids as $comment_id ) {
        wp_delete_comment( $comment_id, true );
    }

    wp_defer_comment_counting( false );

    $post_meta_ids = $wpdb->get_col( $wpdb->prepare( "SELECT meta_id FROM $wpdb->postmeta WHERE post_id = %d ", $postid ) );
    foreach ( $post_meta_ids as $mid ) {
        delete_metadata_by_mid( 'post', $mid );
    }

    /**
     * Срабатывает немедленно перед удалением поста из базы данных.
     *
     * @since 1.2.0
     * @since 5.5.0 Добавлен параметр `$post`.
     *
     * @param int     $postid ID поста.
     * @param WP_Post $post   Объект поста.
     */
    do_action( 'delete_post', $postid, $post );

    $result = $wpdb->delete( $wpdb->posts, array( 'ID' => $postid ) );
    if ( ! $result ) {
        return false;
    }

    /**
     * Срабатывает немедленно после удаления поста из базы данных.
     *
     * @since 2.2.0
     * @since 5.5.0 Добавлен параметр `$post`.
     *
     * @param int     $postid ID поста.
     * @param WP_Post $post   Объект поста.
     */
    do_action( 'deleted_post', $postid, $post );

    clean_post_cache( $post );

    if ( is_post_type_hierarchical( $post->post_type ) && $children ) {
        foreach ( $children as $child ) {
            clean_post_cache( $child );
        }
    }

    wp_clear_scheduled_hook( 'publish_future_post', array( $postid ) );

    /**
     * Срабатывает после удаления поста, в конце wp_delete_post().
     *
     * @since 3.2.0
     * @since 5.5.0 Добавлен параметр `$post`.
     *
     * @see wp_delete_post()
     *
     * @param int     $postid ID поста.
     * @param WP_Post $post   Объект поста.
     */
    do_action( 'after_delete_post', $postid, $post );

    return $post;
}

Параметр s запроса WP ищет посты в столбцах заголовка и содержания таблицы постов. Вы можете использовать это, чтобы сократить свой код. Вот пример, который поможет вам начать.

Вы можете использовать это в wp_footer, чтобы запустить один раз (очень плохая идея оставлять это там, но хороша для тестирования), или создать задание cron для автоматического запуска с выбранным интервалом.

function wpse388545_delete_selected_posts() {

    $get_posts = get_posts(array(
        'post_type' => array('post'),
        'posts_per_page' => -1,
        's' => 'Это искомый запрос',
    ));

    if ( !empty($get_posts) ) {
        foreach( $get_posts as $post ) {
            wp_delete_post($post->ID, true);
        }
    }
}

Ответ или решение

Удаление поста в WordPress по заголовку

Вам необходимо удалить пост в WordPress на основании его заголовка. Ваш текущий код позволяет публиковать или обновлять посты, если они существуют, однако теперь требуется дополнить его функциональностью удаления. Ниже представлено подробное пояснение процесса удаления поста с использованием функции wp_delete_post().

Шаг 1: Подключение к WordPress

Для начала вам нужно подключиться к функционалу WordPress, что вы уже сделали, используя require_once("/var/www/mysite.com/wp-load.php");. Это позволяет вам обращаться ко всем встроенным функциям WordPress.

Шаг 2: Определение функции для поиска поста по заголовку

Вы написали функцию wp_exist_post_by_title, которая позволяет определить, существует ли пост с данным заголовком. Она работает корректно, но её можно улучшить, чтобы сразу возвращать ID найденного поста.

function wp_exist_post_by_title($title) {
    global $wpdb;
    $return_id = $wpdb->get_row($wpdb->prepare("SELECT ID FROM wp_posts WHERE post_title = %s AND post_type = 'post'", $title), 'ARRAY_A');
    return !empty($return_id) ? $return_id['ID'] : false; // возвращаем только ID
}

Шаг 3: Удаление поста при наличии

Теперь вы можете использовать wp_delete_post() внутри вашего основного кода для удаления поста, если он существует. Вот как это можно реализовать:

// require wp-load.php to use built-in WordPress functions
require_once("/var/www/mysite.com/wp-load.php");

// Заголовок поста
$TítleProduct = "Title Product 1";

// Проверяем, существует ли пост
$id = wp_exist_post_by_title($TítleProduct);

if ($id !== false) {
    // Если пост существует, удаляем его
    $deleted = wp_delete_post($id, true); // $force_delete = true для полного удаления
    if ($deleted) {
        echo 'Пост с заголовком "'.$TítleProduct.'" был успешно удален.';
    } else {
        echo 'Произошла ошибка при удалении поста.';
    }
} else {
    echo 'Пост с заголовком "'.$TítleProduct.'" не найден.';
}

Полный пример кода

Весь код будет выглядеть следующим образом:

<?php
// require wp-load.php to use built-in WordPress functions
require_once("/var/www/mysite.com/wp-load.php");

// Заголовок поста
$TítleProduct = "Title Product 1";

// Функция для поиска поста по заголовку
function wp_exist_post_by_title($title) {
    global $wpdb;
    $return_id = $wpdb->get_row($wpdb->prepare("SELECT ID FROM wp_posts WHERE post_title = %s AND post_type = 'post'", $title), 'ARRAY_A');
    return !empty($return_id) ? $return_id['ID'] : false; // возвращаем только ID
}

// Проверяем, существует ли пост
$id = wp_exist_post_by_title($TítleProduct);

if ($id !== false) {
    // Если пост существует, удаляем его
    $deleted = wp_delete_post($id, true); // $force_delete = true для полного удаления
    if ($deleted) {
        echo 'Пост с заголовком "'.$TítleProduct.'" был успешно удален.';
    } else {
        echo 'Произошла ошибка при удалении поста.';
    }
} else {
    echo 'Пост с заголовком "'.$TítleProduct.'" не найден.';
}
?>

Заключение

Используя приведенный выше код, вы сможете легко удалить posts из WordPress по заголовку. Этот метод эффективен и позволяет вам управлять постами на вашем сайте. Не забывайте выполнять тесты в безопасной среде, прежде чем развертывать изменения на живом сайте.

Оцените материал
Добавить комментарий

Капча загружается...