⊗ppPmAuRgtD 434 of 447 menu

Ma'lumotlar bazasini normalizatsiya qilish

Hozirda biz foydalanuvchilarimizning holatlarini foydalanuvchilar o'zlarining jadvalida saqlaymiz. Biroq, bu noto'g'ri - bizda normalizatsiyalanmagan jadval paydo bo'ldi, chunki 'user' va 'admin' so'zlari ko'p marta takrorlanadi.

Normalizatsiyani amalga oshirish kerak - holatlarimizni alohida statuses jadvaliga chiqaramiz:

id name
1 user
2 admin

Va users jadvalida status_id ustunini qilamiz. Endi registratsiya paytida status_id ustuniga statuses jadvalidan holatning id sini yozamiz:

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

Eng murakkab o'zgarishlar avtorizatsiya paytida bo'ladi: foydalanuvchi holatini olish uchun LEFT JOIN ni bajarish kerak bo'ladi:

<?php $login = $_POST['login']; // Foydalanuvchini login bo'yicha olamiz va holatni qo'shamiz: $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']; // holat } else { } } else { } ?>

Avtorizatsiya va registratsiyangizni nazariyada tavsiflanganiga muvofiq o'zgartiring.

Admin panel ishiga o'zgartirishlar kiriting (foydalanuvchi holatlarini ko'rsatish, holatlarni o'zgartirish va hokazo).

Oʻzbek
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекTiếng Việt
Biz sayt ishlashi, tahlil qilish va shaxsiylashtirish uchun cookie-fayllardan foydalanamiz. Ma'lumotlarni qayta ishlash Maxfiylik siyosatiga muvofiq amalga oshiriladi.
hammasini qabul qilish sozlash rad etish