$ wpdb-> вставить код не работает с foreach - PullRequest
0 голосов
/ 19 февраля 2012

Проблема: Должно быть несколько строк, вставляемых в базу данных через $ wpdb-> insert, но новые строки не создаются.

Фон:

  • Я проверил запрос в PhpMyAdmin, и он возвращает 178 строк.
  • Это для плагина Wordpress с функцией, которая запускается при 'init'.
  • Пробовал различные var_dump'sи все еще переменные $ object_id и $ taxo_id кажутся пустыми.

Пожалуйста, помогите!

<?php
    function cb_t2c_cat_updater () {
    global $wpdb;
    $prefix = $wpdb->prefix;

    //This is a truncated version of the valid SQL query, returns 178 rows
      $cb_t2c_cat_update = $wpdb->get_results("SELECT
      ".$prefix."associations.object_id as 'object_id', ".$prefix."associations.term_taxonomy_id as 'taxo_id', ".$prefix."associations.term_id as 'term_id', ".$prefix."associations.cat_ID as 'cat_ID'
    FROM ...
    WHERE...
    ORDER BY object_id ASC, term_id ASC, cat_ID ASC",ARRAY_A);

    foreach ($cb_t2c_cat_update as $values) {
        $table = $prefix . 'term_relationships';
        $object_id = $values['object_id'];
        $taxo_id = $values['taxo_id'];
        $wpdb->insert(
            $table, 
            array( 
                'object_id' => $object_id, 
                'term_taxonomy_id' => $taxo_id,
                'term_order' => 0
                ), 
            array( 
                '%d', 
                '%d',
                '%d',
                    ) 
            );
        }
    }

add_action('init', 'cb_t2c_cat_updater');

?>

1 Ответ

0 голосов
/ 20 февраля 2012

Есть рабочий раствор.
Сделал переменные целыми числами через:

 $num_object_id = (int)$object_id

и затем передал их в запрос вроде:

$wpdb->query("INSERT INTO... ")
...