Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/88.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/spring-boot/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何使用DB和PHP管理用户和组?_Php_Sql_Web Applications - Fatal编程技术网

如何使用DB和PHP管理用户和组?

如何使用DB和PHP管理用户和组?,php,sql,web-applications,Php,Sql,Web Applications,我们为内部团队提供了软件存储库网站,以供访问。 目前有许多用户,并分为不同的组。 为了管理它们,我们使用类似字符串的二进制编号,如“000101”,并检查1及其位置,基于此,我们决定用户属于哪个组 例如, '01111'=>组'test1' '10111'=>组'test2' “11011”=>组“exa1” “11101”=>组“exa2” “11110”=>组“管理员” 我们使用用户访问组进行“和”操作… 用户='someone',访问='01001'。。。表示用户(某人)属于组=>tes


我们为内部团队提供了软件存储库网站,以供访问。
目前有许多用户,并分为不同的组。
为了管理它们,我们使用类似字符串的二进制编号,如“000101”,并检查1及其位置,基于此,我们决定用户属于哪个组

例如,
'01111'=>组'test1'
'10111'=>组'test2'
“11011”=>组“exa1”
“11101”=>组“exa2”
“11110”=>组“管理员”
我们使用用户访问组进行“和”操作…
用户='someone',访问='01001'。。。表示用户(某人)属于组=>test2和admin。

我们将这个二进制字符串存储到DB
现在的情况是组数增加了(60+),我正在寻找新的逻辑,而不是二进制字符串来标识用户和相应的组。

因此,如果有人实现了或知道不同的逻辑,而不是上述逻辑,那么请分享,这将非常有帮助。

提前感谢。

CREATE TABLE groups_members (
    group_id INTEGER NOT NULL,
    member_id INTEGER NOT NULL,
    PRIMARY KEY(member_id, group_id)
);
基本SQL。有一个
成员
表、一个
表和一个将成员映射到组的表。这就是所谓的多对多关系

顺便说一句,你显示的数字没有意义。。。如果您想要60个组,则需要60位长的数字,除非某些组是其他组的超集。要确定组成员身份,它将是OR操作,而不是AND