簡體   English   中英

有沒有辦法將數據插入多個表? php mysql

[英]Is there a way to insert data to multiple tables? php mysql

我一直在嘗試將數據從我的 web 頁面插入到數據庫中的多個表中,但我真的無法弄清楚!

我有這個頁面,用戶可以在其中下訂單,首先他需要獲取客戶詳細信息:

name, age, email etc.

還有他的汽車細節:

the car model and the year of fabrication

在我的數據庫中,我有 2 個鏈接的表 1 - Clients(Client_id (PK), name, email, id_Car(fK),第二個是 Cars (id_Car, model, year_of_fabrication)。

我的主鍵是 Auto_Incremented,所以我不必傳遞值。

我認為問題出在我的外鍵上,因為從網站上我沒有將任何值傳遞給 Clients 表,但我真的不知道如何同時將數據插入到 clients 和 cars 表中。

這是我的訂單表格。

<form action="include/comanda.inc.php">
    <div class="comanda"> 
        <h2 id="titlu">Detaliile clientului:</h2>

        <label for="client">Numele clientului: </label>
        <input type="text" name="client">

        <label for="client">CNP: </label>
        <input type="text" name="cnp">

        <label for="client">Sex: </label>
        <select name="sex" id="sex">
            <option value="M">M</option>
            <option value="F">F</option>
        </select>

        <label for="client">Email: </label>
        <input type="text" name="email">

        <label for="client">Sector: </label>
        <select name="sector" id="sectorCl">
            <option value="1">Sector 1</option>
            <option value="2">Sector 2</option>
            <option value="3">Sector 3</option>
            <option value="4">Sector 4</option>
            <option value="5">Sector 5</option>
            <option value="6">Sector 6</option>
        </select>

    
        <label for="client">Marca masina: </label>
        <input type="text" name="masina">

        <!-- DROPDOWN LIST CU ANII DE LA 2020 LA 2000-->
        <label for="client">Anul Fabricatiei: </label>
        <select name="an_fabricatie" id="an_masina">
        <option value="2020">2020</option>
        <option value="2019">2019</option>
        <option value="2018">2018</option>
        <option value="2017">2017</option>
        <option value="2016">2016</option>
        <option value="2015">2015</option>
        <option value="2014">2014</option>
        <option value="2013">2013</option>
        <option value="2012">2012</option>
        <option value="2011">2011</option>
        <option value="2010">2010</option>
        </select>

這是我的訂單腳本:

<?php 
if(isset($_POST["creaza_comanda"])){
    require 'dbh.inc.php';

    $nume = $_POST["client"];
    $cnp = $_POST["cnp"];
    $sex = $_POST["sex"];
    $email = $_POST["email"];
    $sector = $_POST["sector"];
    $masina = $_POST["masina"];
    $an_fabricatie = $_POST["an_fabricatie"];
    $angajat = $_POST["nume-angajat"];
    $den_furnizor = $_POST["den_furnizor"];
    $oras_furnizor = $_POST["oras_furnizor"];
    $piesa = $_POST["productName"];
    $pret = $_POST["price"];

    if(!preg_match("/^[a-zA-Z ]*$/", $nume)){
        header("Location: ../comanda_noua.php?eroare");
        exit();
    } else if(!preg_match("/^[0-9]*$/",$cnp)){
        header("Location: ../comanda_noua.php?msg2");
        exit();
    } else if (!filter_var($email, FILTER_VALIDATE_EMAIL)){
        header("Location: ../comanda_noua.php?msg2");
        exit();
    } else {
        
       $sql = "INSERT INTO masini (marca, an_fabricatie) VALUES ('$masina', $an_fabricatie);";
       
       if(mysqli_query($conn,$sql)){
           header("Location: ../comanda_noua.php?succes");
           exit();
       } else{
            echo "Error ". $sql . ":-" . mysqli_error($conn);
       }
       mysqli_close($conn);
    }
    header("Location: ../comanda_noua.php");
    exit;
}

您只需從主表中獲取最后一個插入行 id 並將其作為外鍵傳遞給派生表。 當您使用 DOM object 將數據插入 Cars 表時,您需要在此之后編寫此行:

$sql = "INSERT INTO masini (marca, an_fabricatie) VALUES ('$masina', $an_fabricatie);"; 
if(mysqli_query($conn,$sql)){
     $last_id = $conn->insert_id;     // this will gives you last inserted id
    // just after this you can add data to another table
    $sql1 = "INSERT INTO Clients (<column_name>) VALUES ('<values>');";  // change column name and values here;
    if(mysqli_query($conn,$sql1)){
       // after all data insert add your next logic code here.or simply redirect it.
    }
}

或者您也可以使用以下方法獲取 ID:

 $last_id = mysqli_insert_id($conn);

試試這個,我想這會對你有所幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM