在CodeIgniter中使用批插入获取查询的最后插入ID时出错



如何使用CodeIgniter中的批插入获取查询的最后插入ID。我使用了代码$this->db->insert_id(),但它返回了我插入的第一个数组的ID。我找不到最后一个插页。

以下是我所做的:

for ($x = 0; $x < sizeof($filtername); $x++) {
    $orders[] = array(
        'poid'              => null,
        'order_id'          => $poid,
        'item_desc'         => $filtername[$x],
        'item_qty'          => $filterquantity[$x],
        'item_price'        => $filterprice[$x],
        'total'             => $filtertotal[$x],
        'cash_on_delivery'  => $val_delivery,
        'is_check'          => $val_check,
        'bank_transfer'     => $val_transfer,
        'transaction_date'  => $dateorder
    );
}
$this->db->insert_batch('po_order', $orders);
echo $this->db->insert_id(); //will return the first insert array

我看不出我的错误在哪里。我的最后一个选择是使用查询获取它。我也做了mysql_insert_id(),但总是返回到0。

为了提高性能,我认为最好的方法是在循环中使用批插入,而不是单独插入,但要获得最后一个插入id,请添加第一个插入id&受影响的行。

$this->db->insert_batch('po_order', $orders);
$total_affected_rows = $this->db->affected_rows();
$first_insert_id = $this->db->insert_id();
$last_id = ($first_insert_id + $total_affected_rows - 1);

$insertIds  = array();
for ($x = 0; $x < sizeof($filtername); $x++) {
    $orders = array(
        'poid'              => null,
        'order_id'          => $poid,
        'item_desc'         => $filtername[$x],
        'item_qty'          => $filterquantity[$x],
        'item_price'        => $filterprice[$x],
        'total'             => $filtertotal[$x],
        'cash_on_delivery'  => $val_delivery,
        'is_check'          => $val_check,
        'bank_transfer'     => $val_transfer,
        'transaction_date'  => $dateorder
    );
    $this->db->insert('po_order', $orders);
    $insertIds[$x]  = $this->db->insert_id(); //will return the first insert array
}
print_r($insertIds); //print all insert ids

相关内容

  • 没有找到相关文章

最新更新