⊗ppPmAuRgtD 434 of 447 menu

การนอร์มัลไลซ์ฐานข้อมูล

ปัจจุบันเรากำลังเก็บสถานะของผู้ใช้ของเรา ในตารางเดียวกับข้อมูลของผู้ใช้ อย่างไรก็ตาม นี่เป็นวิธีที่ผิด - เราจะได้ ตารางที่ไม่ได้นอร์มัลไลซ์ เนื่องจากคำว่า 'user' และ 'admin' ซ้ำกันหลายครั้ง

จำเป็นต้องทำการนอร์มัลไลซ์ - เราจะแยก สถานะของเราออกมาไว้ในตารางต่างหากชื่อ statuses:

id name
1 user
2 admin

และในตาราง users เราจะสร้างคอลัมน์ status_id ขึ้นมา ตอนนี้เมื่อลงทะเบียน เราจะเขียนค่า id ของสถานะจากตาราง statuses ลงในคอลัมน์ status_id:

<?php $query = "INSERT INTO users SET login='$login', password='$password', status_id='1'"; ?>

การเปลี่ยนแปลงที่ซับซ้อนที่สุดจะเกิดขึ้นเมื่อยืนยันตัวตน: เพื่อที่จะได้สถานะของผู้ใช้ จำเป็นต้องทำ LEFT JOIN:

<?php $login = $_POST['login']; // รับข้อมูลผู้ใช้ตามล็อกอินและ join กับสถานะ: $query = "SELECT users.*, statuses.name as status FROM users LEFT JOIN statuses ON users.status_id=statuses.id WHERE login='$login'"; $res = mysqli_query($link, $query); $user = mysqli_fetch_assoc($res); if (!empty($user)) { $hash = $user['password']; if (password_verify($_POST['password'], $hash)) { $_SESSION['auth'] = true; $_SESSION['status'] = $user['status']; // สถานะ } else { } } else { } ?>

โปรดปรับเปลี่ยนกระบวนการยืนยันตัวตนและการลงทะเบียนของคุณ ให้สอดคล้องกับที่อธิบายไว้ในส่วนทฤษฎี

โปรดทำการเปลี่ยนแปลงในการทำงานของหน้าแอดมิน (การแสดงผล สถานะของผู้ใช้, การเปลี่ยนแปลงสถานะ และอื่นๆ)

ไทย
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣTürkmenTürkçeЎзбекOʻzbekTiếng Việt
เราใช้คุกกี้สำหรับการทำงานของเว็บไซต์ การวิเคราะห์ และการปรับเนื้อหาให้เหมาะสมส่วนบุคคล การประมวลผลข้อมูลเกิดขึ้นตาม นโยบายความเป็นส่วนตัว.
ยอมรับทั้งหมด ปรับแต่ง ปฏิเสธ