Вопрос или проблема
Я хочу удалить пост из 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 по заголовку. Этот метод эффективен и позволяет вам управлять постами на вашем сайте. Не забывайте выполнять тесты в безопасной среде, прежде чем развертывать изменения на живом сайте.