Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP][MySQL] System uprawnień
HuzarO
post
Post #1





Grupa: Zarejestrowani
Postów: 13
Pomógł: 2
Dołączył: 13.04.2012

Ostrzeżenie: (0%)
-----


Witam, chciałbym się dowiedzieć czy jest sens w przechowywaniu danych w bazie danych w ten sposób:

- Każdy użytkownik ma group_id
- Każda grupa ma swoje pole permissions w którym znajduje się suma uprawnień które posiada(wyjaśnienie dalej)
- Każde uprawnienie ma swoje id które jest potęgą liczby 2,

czyli gdy mam uprawnienia:
1 - read own
2 - write post
4 - delete own post
8 - edit own post
16 - read other
32 - edit other
64 - remove other

gdy suma uprawnień użytkownika wynosi 23 to znaczy że może:
- read own
- write post
- delete own post
- read other

Czyli proste operacje bitowe, moje pytanie brzmi czy przechowywanie w ten sposób uprawnień jest dobrym rozwiązaniem, w przypadku gdy tych uprawnień jest całkiem sporo, a co za tym idzie id uprawnien może sięgać ponad 1 milion, gdyż jest to potęga liczby 2. Jak najlepiej przechowywać te uprawnienia w bazie tzn. w jakim typie pola i jego długości, narazie mam int(10) ale uprawnień jest nie dużo, lecz podczas rozbudowywania cms'a dojdzie ich o wiele wiele więcej. Więc chciałbym się dowiedzieć czy jednak jest to dobry sposób czy może Wy znacie jakiś inny, lepszy i bylibyście tak mili aby się nim podzielić. Dziękuję i pozdrawiam (IMG:style_emoticons/default/smile.gif)

Ten post edytował HuzarO 2.03.2013, 21:17:46
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
thek
post
Post #2





Grupa: Moderatorzy
Postów: 4 362
Pomógł: 714
Dołączył: 12.02.2009
Skąd: Jak się położę tak leżę :D




Do pewnego punktu bitowy zapis ma sens (zakres int czy potem bigint), ale jak sam zauważyłeś, im więcej tym i komplikacji niemało. Z czasem myślę, że przejście na relację many-to-many stanie się raczej koniecznością i chyba w tą stonę powinieneś pomyśleć póki nie masz do przepisania systemu całego.
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 16.09.2025 - 06:42