繁体   English   中英

$ wpdb->插入代码不适用于foreach

[英]$wpdb->insert code not working with foreach

问题:应该通过$ wpdb-> insert将一堆行插入数据库,但是没有创建新行。

背景:

  • 我已经检查了PhpMyAdmin中的查询,它返回178行。
  • 这是针对具有在“ init”上触发的功能的Wordpress插件。
  • 尝试了各种var_dump,但变量$ 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');

?>

有一个可行的解决方案。
通过以下方式使变量为整数:

 $num_object_id = (int)$object_id

然后将它们传递给查询,例如:

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM