دورة mysql للمبتدئين الدرس الرابع

منذ 5 سنوات imadbelasri Mysql
MS

فهاد الدرس الرابع من دورة mysql للمبتدئين غادي نشوفوا كيفاش نجمعوا مابين php و mysql غادي نزيدو فورم لي غادي تمكنا من إضافة مستخدين لقاعدة البيانات من بعد غادي نعرضوا هاد المستخدمين فجدول مع روابط التعديل والحدف.


1- إضافة فورم إضافة المستخدمين

فباش نتمكن من إضافة مستخدمين جداد لقاعدة البيانات عكس الطريقة لي شفنا قبل لي كنا كنزيدو القيم ف requête دبا غادي نزيدو فورم لي غادي ندخلو فيها المعلومات الخاصين بمستخدم ومنبعد يتزاد فقاعدة البيانات الكود باش زدنا الفورم :

                                                    
                                                        //index.php

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>Php Cours</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" type="text/css" media="screen" href="main.css" />
    <script src="main.js"></script>
</head>
<body>
    <form action="index.php" method="post">
        <label for="nom">Nom</label>
        <input type="text" name="nom" id="nom"><br>
        <label for="prenom">Prénom</label>
        <input type="text" name="prenom" id="prenom"><br>
        <label for="email">Email </label>
        <input type="text" name="email" id="email"><br>
        <input type="submit" value="valider">
    </form> 
</body>
</html>
                                                    
                                                

2- إضافة مستخدم لقاعدة البيانات

باش نزيد مستخدم فقاعدة البيانات  كنسترجع القيم لي دخلنا فالفورم باستعمال POST_$ هادشي راه سبق شفناه فالدروس الخاصة ب PHP منبعد كنزيدها ف des variables لي سميتهم nom,$prenom,$email$.
منبعد كنزيد requête sql لي كنعطيها les variables لي غادي تزيد مع الحقول لي حددت ثم كنفذها دازت كنعرض رسالة نجاح مدازتش كنعرض العكس.
الكود لي زدنا هو :

                                                        
                                                            //index.php

<?php
    $host = 'localhost';
    $user = 'root';
    $password = '';
    $db = 'php_course';
    //open connection
    $con = new mysqli($host,$user,$password,$db);
    //get for data
    if(isset($_POST['submit'])){
        $nom = htmlspecialchars(trim($_POST['nom']));
        $prenom = htmlspecialchars(trim($_POST['prenom']));
        $email = htmlspecialchars(trim($_POST['email']));
        //insert data
        $sql = "INSERT INTO users (nom,prenom,email) VALUES ('$nom','$prenom','$email')";
        if($con->query($sql)){
            echo 'utilisateur ajouté';
        }else{
            echo 'Erreur'.$con->error;
        }
    }
    //close connection
    $con->close();
?>
                                                        
                                                    

3- استرجاع وعرض المستخدمين

باش نسترجع و نعرض المستخدمين كنخدم بل boucle while لي سبق شفنا.
كنخدم بل fonction fetch_assoc لي كتحول المعلومات لجدول منبعد كنعطيهم لل variable $row لي منبعد كنعرضهم باستعمال ل index.
فالمثال لي عندنا هادشي لي درنا زدنا table لي عرضناها ب echo منبعد درنا ل boucle باش عرضنا المستخدمين.
كنزيد ايضا روابط الحذف والتعديل لي كيرسلو ل id ديال المستخدم لي غادي نعدل أو نحذف مع variable سميناها action باش نعرفوا شنو هي العملية لي غادي نفذو.
الكود لي زدنا هو :

                                                        
                                                            //index.php

<table>
    <thead>
        <th>Nom</th>
        <th>Prénom</th>
        <th>Email</th>
        <th>Action</th>
    </thead>
    <tbody>
<?php
    $host = 'localhost';
    $user = 'root';
    $password = '';
    $db = 'php_course';
    //open connection
    $con = new mysqli($host,$user,$password,$db);
    //get for data
    if(isset($_POST['submit'])){
        $nom = htmlspecialchars(trim($_POST['nom']));
        $prenom = htmlspecialchars(trim($_POST['prenom']));
        $email = htmlspecialchars(trim($_POST['email']));
        //insert data
        $sql = "INSERT INTO users (nom,prenom,email) VALUES ('$nom','$prenom','$email')";
        if($con->query($sql)){
            echo 'utilisateur ajouté';
        }else{
            echo 'Erreur'.$con->error;
        }
    }
    //show data
    $sql = "SELECT * FROM users";
    $result = $con->query($sql);
    while($row = $result->fetch_assoc()):
?>   
<tr>
    <td><?php echo $row['nom'];?></td>
    <td><?php echo $row['prenom'];?></td>
    <td><?php echo $row['email'];?></td>
    <td><a href="index.php?action=delete&id=<?php echo $row['id'];?>">supprimer</a></td>
    <td><a href="index.php?action=update&id=<?php echo $row['id'];?>">modifier</a></td>
</tr>  
<?php
    endwhile;
    //close connection
    $con->close();
?>
    </tbody>
</table>
                                                        
                                                    

4- تعديل مستخدم باستعمال id

باش نعدل مستخدم بل id ديالو كنخدم ب requête sql UPDATE لي سبق شفناها فالدروس السابقة.
فالمثال ديالنا ملي كنكليكي على modifier كنسترجع ل id ديال المستخدم وكنتحقق من action بلي modifier منبعد كنسترجع المستخدم بل id وكنعمر الفورم بالمعلومات ديالو.
زدت فالفورم bouton لي كيمكن من التعديل فالكود php كنسترجعوا وكنسترجع القيم لي دخلت جداد فالفورم وكندير التعديل ب requête sql لي سبق شفنا نجحت كنعرض رسالة  نجاح منجحتش كنعرض العكس الكود لي زدنا هو :

                                                        
                                                            //index.php

<?php
    endwhile;
    //update data
    if(isset($_GET['id']) && $_GET['id'] !== null && $_GET['action'] === 'update'){
        $id = htmlspecialchars(trim($_GET['id']));
        $sql = "SELECT * FROM users WHERE id = $id";
        $result = $con->query($sql);
        $row = $result->fetch_assoc();
    }
    if(isset($_POST['update'])){
        $nom = htmlspecialchars(trim($_POST['nom']));
        $prenom = htmlspecialchars(trim($_POST['prenom']));
        $email = htmlspecialchars(trim($_POST['email']));
    //update data
        $id = htmlspecialchars(trim($_POST['id']));
        $sql = "UPDATE users SET nom = '$nom',prenom = '$prenom',email = '$email' WHERE id = $id";
        if($con->query($sql)){
            echo 'utilisateur modifié';
        }else{
            echo 'Erreur'.$con->error;
        }
    }
    //close connection
    $con->close();
?>
    </tbody>
</table>  
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>Php Cours</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" type="text/css" media="screen" href="main.css" />
    <script src="main.js"></script>
</head>
<body>
    <form action="index2.php" method="post">
        <label for="nom">Nom</label>
        <input type="text" name="nom" id="nom" value="<?php echo isset($row['nom']) ? $row['nom'] : '';?>"><br>
        <label for="prenom">Prénom</label>
        <input type="text" name="prenom" id="prenom" value="<?php echo isset($row['prenom']) ? $row['prenom'] : '';?>"><br>
        <label for="email">Email </label>
        <input type="hidden" name="action" value="<?php echo isset($_GET['action']) ? $_GET['action'] : '';?>">
        <input type="hidden" name="id" value="<?php echo isset($_GET['id']) ? $_GET['id'] : '';?>">
        <input type="text" name="email" id="email" value="<?php echo isset($row['email']) ? $row['email'] : '';?>"><br>
        <input type="submit" name="submit" value="valider">
        <input type="submit" name="update" value="modifier">
    </form> 
</body>
</html>
                                                        
                                                    

5- حذف مستخدم باستعمال id

باش نمسح المستخدم كنخدم ب requête sql DELETE لي سبق شفنا كنسترجع ل ID ديال المستخدم من بعد كنقلب عليه ب requête وكنمسحوا الكود لي زدنا هو :

                                                        
                                                            //index.php

<?php
    endwhile;
    //update data
    if(isset($_GET['id']) && $_GET['id'] !== null && $_GET['action'] === 'update'){
        $id = htmlspecialchars(trim($_GET['id']));
        $sql = "SELECT * FROM users WHERE id = $id";
        $result = $con->query($sql);
        $row = $result->fetch_assoc();
    }
    if(isset($_POST['update'])){
        $nom = htmlspecialchars(trim($_POST['nom']));
        $prenom = htmlspecialchars(trim($_POST['prenom']));
        $email = htmlspecialchars(trim($_POST['email']));
    //update data
        $id = htmlspecialchars(trim($_POST['id']));
        $sql = "UPDATE users SET nom = '$nom',prenom = '$prenom',email = '$email' WHERE id = $id";
        if($con->query($sql)){
            header('location:index2.php');
            echo 'utilisateur modifié';
        }else{
            echo 'Erreur'.$con->error;
        }
    }
    //delete data
    if(isset($_GET['id']) && $_GET['id'] !== null && $_GET['action'] === 'delete'){
        $id = htmlspecialchars(trim($_GET['id']));
        $sql = "DELETE FROM users WHERE id = $id";
        if($con->query($sql)){
            header('location:index2.php');
            echo 'utilisateur supprimé';
        }else{
            echo 'Erreur'.$con->error;
        }
    }
    //close connection
    $con->close();
?>