⊗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']; // ვიღებთ მომხმარებელს ლოგინის მიხედვით და ვაერთებთ სტატუსს: $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
ვებსაიტის მუშაობის, ანალიტიკისა და პერსონალიზაციისთვის ვიყენებთ ქუქი-ფაილებს. მონაცემთა დამუშავება ხდება Კონფიდენციალურობის პოლიტიკის შესაბამისად.
ყველას მიღება პარამეტრები უარყოფა