⊗ppPmAuRgtD 434 of 447 menu

Нормализация на базата данни

В момента съхраняваме статусите на нашите потребители в същата таблица, в която са и самите потребители. Това обаче не е правилно - получава се ненормализирана таблица, тъй като думите 'user' и 'admin' се повтарят многократно.

Необходимо е да се извърши нормализация - ще изнесем нашите статуси в отделна таблица statuses:

id name
1 user
2 admin

А в таблицата users ще направим колона status_id. Сега при регистрация в колоната status_id ще записваме id на статуса от таблицата statuses:

<?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
Ние използваме бисквитки за работата на сайта, анализ и персонализация. Обработката на данни се извършва в съответствие с Политика за поверителност.
приемам всички настройки отхвърляне