一次为单个外键插入多个记录

时间:2016-10-15 11:33:29

标签: php mysql codeigniter

基于insert multiple rows using one forigenk value in form

enter image description here

根据上图,选择项目有下拉菜单。选择项目,用户可以添加其他详细信息。现在我想做的是当表单提交project_id时(下拉列表中带有项目名称的id地图)应该插入其他行。
但在我的情况下,project_id只插入第一行。下面的结果是我打印阵列时出现的。

  

数组([0] =>数组([project_id] => 1 [staff_id] => 2 [item_no] =>   1 [描述] => 1 [数量] => 1 [单位] => cube [rate] => 1   [laboure_hrs] => 1 [laboure_cost] => 1 [金额] => 2)1 =>阵列(   [project_id] => [staff_id] => 2 [item_no] => 2 [描述] => 2   [qty] => 2 [单位] => sq.ft [rate] => 2 [laboure_hrs] => 2   [laboure_cost] => 2 [金额] => 8)[2] =>数组([project_id] =>   [staff_id] => 2 [item_no] => 3 [描述] => 3 [数量] => 3 [unit] =>   cube [rate] => 3 [laboure_hrs] => 3 [laboure_cost] => 3 [金额] => 18   ))

我如何将project_id传递给其他字段。我的代码在下面

CONTROLER

public function create(){

//    validate fields
            $this->form_validation->set_rules('work_product_id', 'Work Product Id', 'required');
            $this->form_validation->set_rules('work_item_description', 'Work Item Description', 'required');
            $this->form_validation->set_rules('quantity', 'Quantity', 'required');
           $this->form_validation->set_rules('rate', 'Rate', 'required|numeric');
           $this->form_validation->set_rules('laboure_hrs', 'Laboure Hrs', 'required|numeric');
            $this->form_validation->set_rules('laboure_cost', 'Laboure Cost', 'required|numeric');

           if ($_POST) 
   {
        $project_id=$this->input->post('project');
        $staff_id=$this->input->post('staff_id');
        $item_no=$this->input->post('work_product_id');
        $description=$this->input->post('work_item_description');
        $qty=$this->input->post('quantity');
        $unit=$this->input->post('unit');
        $rate=$this->input->post('rate');
        $laboure_hrs=$this->input->post('laboure_hrs');
        $laboure_cost=$this->input->post('laboure_cost');
        $amount=$this->input->post('txtmultTotal');
           $data= [];

   for ($i = 0; $i < count($this->input->post('work_product_id')); $i++)
    {
       $data[$i] = array(
           'project_id' => $project_id
           'staff_id' => $staff_id[$i],
           'item_no' => $item_no[$i],
           'description' => $description[$i],
           'qty' => $qty[$i],
           'unit' => $unit[$i],
           'rate' => $rate[$i],
           'laboure_hrs' => $laboure_hrs[$i],
           'laboure_cost' => $laboure_cost[$i],
           'amount' => $amount[$i],
        );
       }
        print_r($data);
       $this->boq_model->create($data);
    }      

}

模型

function create($data){

     $this->db->insert_batch('boq',$data);

        }

2 个答案:

答案 0 :(得分:0)

我认为您要在project表中插入一行,然后使用item列的值作为外键在您的project_id表中插入几行。

(尊重,您的问题很难理解;如果您从具有良好英语技能的人那里获得帮助,您可能会得到比我更好的答案。)

这是你做的。

首先,在您的project表中插入一行。不要在INSERT查询中提及project_id列,因此MySQL将分配一个自动增量主键。

  INSERT INTO project (name, whatever) VALUES (?, ?);

然后,retrieve the value of the autoincrementing ID using LAST_INSERT_ID()如下。

  SET @project_id := LAST_INSERT_ID();

然后,使用该值将行插入item表。

 INSERT INTO item (project_id, description, qty, whatever)
           VALUES (@project_id, ?, ?, ?)

诀窍是在主表插入后立即检索LAST_INSERT_ID()的值,并将其存储在MySQL user-defined variable @project_id中。然后在每次插入详细信息表时使用它。

答案 1 :(得分:0)

从你的html中,project_id不是一个控件数组。所以你应该做的是在循环之前检索project_id并在循环中使用它或删除循环中project_id前面的[$ i]