Comment puis-je créer un tableau d'insertion par lots CI qui est comme
$data = array(
array(
'title' => 'My title' ,
'name' => 'My Name' ,
'date' => 'My date'
),
array(
'title' => 'Another title' ,
'name' => 'Another Name' ,
'date' => 'Another date'
)
);
de mon tableau normal qui est
Array
(
[0] => Array
(
[track_id] =>
[camp_id] => 1
[field_name] => email_title
[field_value] => sample
)
[1] => Array
(
[track_id] =>
[camp_id] => 1
[field_name] => email_date
[field_value] => 2013-07-02
)
[2] => Array
(
[track_id] =>
[camp_id] => 1
[field_name] => email_template
[field_value] => 2
)
)
Essaye ça:
$data = array(
array(
'title' => 'My title' ,
'name' => 'My Name' ,
'date' => 'My date'
),
array(
'title' => 'Another title' ,
'name' => 'Another Name' ,
'date' => 'Another date'
)
);
$this->db->insert_batch('mytable', $data);
Pour plus d'informations, lisez ici
Ce sont vos données Au contrôleur
$dataForDb[0]['track_id']=$data['track_id'];
$dataForDb[0]['camp_id']=$data['camp_id'];
$dataForDb[0]['field_name']=$data['field_name'];
$dataForDb[0]['field_value']=$data['field_value'];
$dataForDb[1]['track_id']=$data['track_id'];
$dataForDb[1]['camp_id']=$data['camp_id'];
$dataForDb[1]['field_name']=$data['field_name'];
$dataForDb[1]['field_value']=$data['field_value'];
$dataForDb[2]['track_id']=$data['track_id'];
$dataForDb[2]['camp_id']=$data['camp_id'];
$dataForDb[2]['field_name']=$data['field_name'];
$dataForDb[2]['field_value']=$data['field_value'];
$fid=$this->model_modelName->functionName($dataForDb);
Et insérer des données en tant qu'insertion par lots sur le modèle
$this->db->insert_batch($table, $data);
Merci
Votre tableau est correct. Mettez simplement votre tableau dans une variable comme
$data=array();//put your array
et alors
$this->db->insert_batch('yourTable', $data);
Veuillez me faire savoir si vous rencontrez un problème.
votre structure de tableau normale correspond à la structure de tableau de l'insertion par lots.
il suffit donc d'utiliser la requête d'insertion par lots pour insérer les données.
$this->db->insert_batch('yourTable', $data);
$ data est votre tableau normal.