- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
// $conn - mysqli_object
 $query = "insert into orders values
            ('0', '".$customerid."', '".$_SESSION['total_price']."',
            '".$date."', '".PARTIAL."', '".$ship_name."',
            '".$ship_address."', '".$ship_city."',
            '".$ship_state."', '".$ship_zip."',
            '".$ship_phone."', '".$ship_mail."')";
  $result = $conn->query($query) ;
  if (!$result) {
    return false;
  }
//amount - float
  $query = "select orderid from orders where
          customerid = '".$customerid."' and
          amount > (".$_SESSION['total_price']."-.001) and
          amount < (".$_SESSION['total_price']."+.001) and
          date = '".$date."' and
          order_status = 'PARTIAL' and
          ship_name = '".$ship_name."' and
          ship_address = '".$ship_address."' and
          ship_city = '".$ship_city."' and
          ship_state = '".$ship_state."' and
          ship_zip = '".$ship_zip."' and
          ship_country = '".$ship_country."'";
  $result = $conn->query($query);
  if ($result->num_rows > 0) {
    $order = $result->fetch_object();
    $orderid = $order->orderid;
  } else {
    return false;
  }
                                     
        
            Источник: Люк Веллинг и Лора Томсон: Разработка веб-приложений с помощью PHP и MySQL(4 издание стр 594)
Как выдрать last_insert_id? Очень просто: нужно составить запрос на select вставленного orderid с указанием всех вставленных значений в поля, а для флоата указать на всякий случай интервал, и только тогда можно из выборки извлечь вставленный id
ps: констатна PARTIAL нигде не задаётся=)