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