MySQL: выбор элементов для навигации на основе двоичных прав

Я настроил простое управление правами, основанное на двоичном добавлении.

Каждая навигационная запись в моей базе данных имеет следующую структуру:

Таблица записей навигации
и так далее..

У каждого пользователя свой уровень доступа.

пользователь = 3 (1 + 2 — уровень доступа)
admin = 15 (1 + 2 + 4 + 8)

Все идет нормально. Моя проблема сейчас, выбирая соответствующие поля из таблицы через MySQL. Мой первый подход состоял в том, чтобы выбрать все записи с уровнем доступа <= сумма пользователей access_level, но очень скоро я понял, что сюда входят и другие страницы с более низким уровнем доступа.

0

Решение

Вы должны использовать двоичное И, чтобы увидеть, установлен ли бит. Вы также можете использовать поле набора. это также битовое поле с именованием каждого бита.

А вот так:

WHERE (access_level & 15);

образец — создать таблицу и заполнить

mysql> CREATE TABLE `access_table` (
->   `id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT,
->   `item_text` VARCHAR(32) DEFAULT NULL,
->   `url` VARCHAR(32) DEFAULT NULL,
->   `access_level` SET('home','help','backend','admin') DEFAULT NULL,
->   PRIMARY KEY (`id`)
-> ) ENGINE=INNODB DEFAULT CHARSET=utf8;
Query OK, 0 rows affected (0,02 sec)

mysql>
mysql> INSERT INTO `access_table` (`id`, `item_text`, `url`, `access_level`)
-> VALUES
->     (1, 'home', '/home', 'home'),
->     (2, 'help', '/help', 'help'),
->     (3, 'backend', '/backend', 'backend'),
->     (4, 'hoadmpage', '/admin', 'admin');
Query OK, 4 rows affected (0,00 sec)
Records: 4  Duplicates: 0  Warnings: 0

mysql>

образец — показать все строки и выбрать некоторые через биты

mysql> SELECT *,access_level+0 FROM ACCESS_TABLE;
+----+-----------+----------+--------------+----------------+
| id | item_text | url      | access_level | access_level+0 |
+----+-----------+----------+--------------+----------------+
|  1 | home      | /home    | home         |              1 |
|  2 | help      | /help    | help         |              2 |
|  3 | backend   | /backend | backend      |              4 |
|  4 | hoadmpage | /admin   | admin        |              8 |
+----+-----------+----------+--------------+----------------+
4 rows in set (0,00 sec)

mysql>
mysql> SELECT *,access_level+0
-> FROM ACCESS_TABLE
-> WHERE (access_level & 15);
+----+-----------+----------+--------------+----------------+
| id | item_text | url      | access_level | access_level+0 |
+----+-----------+----------+--------------+----------------+
|  1 | home      | /home    | home         |              1 |
|  2 | help      | /help    | help         |              2 |
|  3 | backend   | /backend | backend      |              4 |
|  4 | hoadmpage | /admin   | admin        |              8 |
+----+-----------+----------+--------------+----------------+
4 rows in set (0,00 sec)

mysql> SELECT *,access_level+0
-> FROM ACCESS_TABLE
-> WHERE (access_level & 7);
+----+-----------+----------+--------------+----------------+
| id | item_text | url      | access_level | access_level+0 |
+----+-----------+----------+--------------+----------------+
|  1 | home      | /home    | home         |              1 |
|  2 | help      | /help    | help         |              2 |
|  3 | backend   | /backend | backend      |              4 |
+----+-----------+----------+--------------+----------------+
3 rows in set (0,00 sec)

mysql> SELECT *,access_level+0
-> FROM ACCESS_TABLE
-> WHERE (access_level & 9);
+----+-----------+--------+--------------+----------------+
| id | item_text | url    | access_level | access_level+0 |
+----+-----------+--------+--------------+----------------+
|  1 | home      | /home  | home         |              1 |
|  4 | hoadmpage | /admin | admin        |              8 |
+----+-----------+--------+--------------+----------------+
2 rows in set (0,00 sec)

mysql>
1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]