⊗ppPmAuRgtD 434 of 447 menu

Datu bāzes normalizācija

Šobrīd mēs glabājam savu lietotāju statusus tajā pašā tabulā, kurā pašus lietotājus. Tas tomēr ir nepareizi - mēs iegūstam nenormalizētu tabulu, jo vārdi 'user' un 'admin' atkārtojas daudz reižu.

Ir nepieciešams veikt normalizāciju - izveidosim mūsu statusus atsevišķā tabulā statuses:

id name
1 user
2 admin

Un tabulā users izveidosim kolonnu status_id. Tagad reģistrācijas laikā mēs kolonnā status_id ierakstīsim id statusu no tabulas statuses:

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

Sarežģītākās izmaiņas notiks autentifikācijas laikā: lai iegūtu lietotāja statusu, būs jāizpilda LEFT JOIN:

<?php $login = $_POST['login']; // Iegūstam lietotāju pēc lietotājvārda un pievienojam statusu: $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']; // statuss } else { } } else { } ?>

Pārveidojiet savu autentifikāciju un reģistrāciju saskaņā ar teorijā aprakstīto.

Ieviest izmaiņas administratora paneļa darbībā (lietotāju statusu attēlošana, statusu izmaiņas un tā tālāk).

Latviešu
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Mēs izmantojam sīkdatnes, lai nodrošinātu vietnes darbību, analīti un personalizāciju. Datu apstrāde notiek saskaņā ar Konfidencialitātes politiku.
pieņemt visus iestatīt noraidīt