⊗ppPmAuRgtD 434 of 447 menu

База маълумотларини нормаллаштириш

Ҳозир биз фойдаланувчиларимизнинг статусларини ўзи фойдаланувчилар жойлашган жадвалнинг ўзида сақлаймиз. Бирок, бу нотўғри - бизда нормаллаштирилмаган жадвал ҳосил бўлди, чунки 'user' ва 'admin' сўзлари кўп марта такрорланмоқда.

Нормаллаштиришни амалга ошириш зарур - биз статусларимизни алаҳида statuses жадвалига чиқарамиз:

id name
1 user
2 admin

Ва users жадвалида status_id устунни ҳосил қиламиз. Энди регистрация пайтида биз status_id устунга statuses жадвалидан олинган id статусини ёзамиз:

<?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 { } ?>

Сизнинг авторизация ва регистрацияингзни назарияда баён этилганга мувофиқ равишда ўзгартиринг.

Админканинг ишига ўзгаришлар киритинг (фойдаланувчилар статусларини кўрсатиш, статусларни ўзгартириш ва ҳоказо).

Ўзбек
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeOʻzbekTiếng Việt
Биз веб-сайт ишлаши, таҳлил қилиш ва персоналлаштириш учун кукидан фойдаланамиз. Маълумотларни қайта ишлаш Махфийлик сиёсатига мувофиқ амалга оширилади.
ҳаммасини қабул қилиш мослаштириш рад этиш