duannv2081 2014-01-13 07:52
浏览 31
已采纳

使用循环插入多行时获取成功确认

How can I get success confirmation while I am using loop to insert table rows in MySql database table?

My code is like below (I am using CodeIgniter):

foreach($bookids as $key=>$bookid)
{
    $this->db->query("INSERT INTO `book` (`invoice_id`,`item_id`,`quantity`,`price`) VALUES (`$invoice_id`,`$product_id`,`$product_quantitys[$key]`,`$product_prices[$key]`)");        
}

I would like to get confirmation after all rows inserted successfully.

  • 写回答

2条回答 默认 最新

  • dslf46995 2014-01-13 08:03
    关注

    You can use affected_rows() function to check data inserted( or updated) or not.

    $actual_count = count($bookids); // array of book ids
    $inserted_count = 0;
    
    foreach($bookids as $key=>$bookid)
    {
        $this->db->query("INSERT INTO `book` (`invoice_id`,`item_id`,`quantity`,`price`) VALUES (`$invoice_id`,`$product_id`,`$product_quantitys[$key]`,`$product_prices[$key]`)");        
        if($this->db->affected_rows()>0) // data inserted, so it will return 1
        {
          $inserted_count ++;
        }
    }
    
    if($actual_count  == $inserted_count )
    {
      //throws success message to controller
    }
    else
    {
       // throws error message with mismatch record count
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器