web-dev-qa-db-fra.com

Comment créer un tableau d'insertion par lots Codeigniter

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
        )
)
25
Happy Coder

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

61
Erman Belegu

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

4
Pullat Junaid

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.

2
ABorty

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.

0
bipen