1

我正在使用以下语句通过 codeigniter 在 mysql 中插入数据。

$this->db->insert_batch($table, $query);  

$query动态生成的每个数组元素可以有不同数量的列

也许元素的数量可能会因条件而异

    array (
        0 => array(
            'column1'=>'insert1',
            'column2'=>'insert2'
        ),
        1 => array(
            'column1'=>'insert1';
            'column2'=>'insert2',
            'column4'=>'insert4'
        )
)

这会导致错误或从聋哑处理 codigniter 吗?

我正在构建查询,如下所示

foreach ($sql_xml as $children) {
    $children = $this->xml2array($children);
    foreach ($children as $index => $child) {
        if ($child != 'feed_id') {
            $keys[$index] = $child;
        } 
    }
}

switch (strtolower($this->config[0]->affiliate)) {
    case 'case1':
        $target_xml = $target_xml->productItems;
        break;
    case 'case2':
        $target_xml = $target_xml;
        break;
    default :
        break;
}

$query = array();
$data = array();
foreach ($target_xml as $feeds) {
    $feeds = $this->xml2array($feeds);
    $columns = new RecursiveIteratorIterator(new RecursiveArrayIterator($feeds));
    foreach ($columns as $index => $column) {            
        if (array_key_exists($index, $keys)) {
            if($column != ''){
            $data[$keys[$index]] = $column;
            $data['feed_id']   = $this->id;
            }
            //*TODO //$data['affiliate'] = "'.$this->config[0]->affiliate.'";
        }                
    }
   $query[] = $data;

}


if (count($query > 0)) {
 foreach ($query as $t){

        $this->db->insert($table, $t); 
    }
}
4

1 回答 1

2

数组需要具有相同数量的“列”。
所以我建议如下(null如果没有数据,则将某些列设置为):

array (
    0 => array(
        'column1' => 'insert1',
        'column2' => 'insert2',
        'column3' => null,
        'column4' => null
    ),
    1 => array(
        'column1' => 'insert1',
        'column2' => 'insert2',
        'column3' => 'insert3',
        'column4' => 'insert4'
    )
)

此外,您的语法无效并且会导致错误,因为您在第一列插入时使用的是 a;而不是a 。,

于 2013-08-26T20:59:50.277 回答