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

Сейчас мы храним статусы наших пользователей в той же таблице, где и самих пользователей. Это, однако, неправильно - у нас получается не нормализованная таблица, ведь слова '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']; // Получаем юзера по логину и джойним статус: $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 { } ?>

Переделайте вашу авторизацию и регистрацию в соответствии с описанным в теории.

Внесите изменения в работу админки (вывод статусов пользователей, изменения статусов и так далее).



Чат с GPT Компилятор