Используйте переменную PHP в инструкции SQL

#php #mysql #sql #database #wordpress

#php #mysql #sql #База данных #wordpress

Вопрос:

Я использую WordPress, и у меня есть инструкция SQL (как показано ниже) для сбора тегов для определенной категории. Единственная проблема с этим заключается в том, что имена таблиц могут меняться (т. Е. они не всегда будут wp_ *). Функция $pfx = $wpdb->base_prefix; возвращает префикс базы данных WordPress.

Как я могу использовать $pfx внутри моей инструкции SQL ниже (вместо wp_).

 global $wpdb;
$tags = $wpdb->get_results
("
SELECT DISTINCT terms2.term_id as tag_id, terms2.name as tag_name, null as tag_link, t2.count as post_total
    FROM
        wp_posts as p1
        LEFT JOIN wp_term_relationships as r1 ON p1.ID = r1.object_ID
        LEFT JOIN wp_term_taxonomy as t1 ON r1.term_taxonomy_id = t1.term_taxonomy_id
        LEFT JOIN wp_terms as terms1 ON t1.term_id = terms1.term_id,

        wp_posts as p2
        LEFT JOIN wp_term_relationships as r2 ON p2.ID = r2.object_ID
        LEFT JOIN wp_term_taxonomy as t2 ON r2.term_taxonomy_id = t2.term_taxonomy_id
        LEFT JOIN wp_terms as terms2 ON t2.term_id = terms2.term_id

    WHERE
        t1.taxonomy = 'category' AND p1.post_status = 'publish' AND terms1.term_id IN (".$args['categories'].") AND
        t2.taxonomy = 'post_tag' AND p2.post_status = 'publish'
        AND p1.ID = p2.ID
    ORDER BY post_total DESC
");
  

Спасибо.

Ответ №1:

Изменить, например

 LEFT JOIN wp_term_relationships 
  

в

 LEFT JOIN ".$pfx."term_relationships 
  

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

1. Извините, я неправильно взял кавычки, поскольку вы используете двойные кавычки. Исправлено.

2. Спасибо, но я уже пробовал использовать двойные кавычки, и снова это все еще не работает. Я не совсем уверен, что происходит..

3. Вы убедились, что $ pfx действительно содержит значение и что указанная таблица действительно существует? Кроме того, вы получаете какие-либо ошибки, когда вы это делаете? Просто сказать, что это «не работает», не поможет нам помочь вам.

4. Да, я могу проверить, что переменная $pfx действительно содержит правильный префикс базы данных. Однако запрос на самом деле является функцией, которой передается идентификатор категории и (если все это работает) возвращаются теги указанной категории. Однако после изменения wp_ с ".$pfx." помощью функция не возвращает никаких тегов при использовании.

5.Вы установили $pfx внутри функции и сбросили ее содержимое туда, не так ли?