dongsu3664 2017-06-11 12:27
浏览 23
已采纳

获取刚刚插入的数据库中的行的id

I'm want to insert the id of every item in the cart to the database and couple this invoice line to an invoice that just has been created in the same case. at the moment if i press the button its adding a new invoice to the database and after this its adding every single product in the cart but now i need to replace the 1 in the second query with the invoice id that just has been created. How can i get this to work?

  case "apply":
  $curdate = date('Y-m-d');
  // new invoice
  $sql = "INSERT INTO invoice (user_user_id, dates) VALUES ('1', '$curdate')";
  $result = mysqli_query($con, $sql);
  // for each item in cart insert into invoiceline
  foreach ($_SESSION["cart_item"] as $item){
    $car = $item["id"];
    $sql = "INSERT INTO invoice_line (car_car_id, invoice_invoice_number) VALUES ('$car', '1')";
    $result = mysqli_query($con, $sql);

  }
    unset($_SESSION["cart_item"]);
  break;
}
}

The invoice_id is not the primary but a foreign key, the table doenst have a primary key so i dont think i can use mysqli_insert_id?

  • 写回答

1条回答 默认 最新

  • duanshan3331 2017-06-11 12:36
    关注

    You can use:

    $inserted_id = mysqli_insert_id($con);
    

    or, object oriented style:

    $inserted_id = $con->insert_id;
    

    $inserted_id will have the value of just inserted row (should be auto-increment in your table).

    So, your second query will look like:

    $sql = "INSERT INTO invoice_line (car_car_id, invoice_invoice_number) VALUES ('$car', '$inserted_id')";
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化