- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我们正在开发一个网站,该网站将具有大约 5 个不同的用户角色,每个角色具有不同的属性。在当前版本的数据库架构中,我们有一个用户表,其中包含所有用户及其所有属性。
问题是我们需要的属性因用户角色而异。所有用户都具有相同的基本属性,例如姓名、电子邮件地址和密码。但最重要的是,属性因角色而异。有些有社交媒体链接,有些有发票地址等。总共可能有多达 60 列(属性),每个用户角色仅使用其中的一部分。
表中总共可能有大约 250,000 个用户,其中最大部分(大约 220,000)属于单个用户角色(并使用 60 列中的大约 20 列)。其他 30,000 名用户分为四个其他规则,并使用其他 40 列的子集。
从数据库作为开发的角度来看,最好的数据库结构是什么?我的想法是有一个基本的 users 表,然后用像 users_ moderators 这样的表扩展它,但这可能会导致很多加入的查询。防止这种情况发生的一种方法是使用 VIEW,但我读过一些(过时的?)文章,认为 VIEW 可能会损害性能,例如:http://www.mysqlperformanceblog.com/2007/08/12/mysql-view-as-performance-troublemaker/ .
“完美”的结构是否存在?任何建议,或者这根本不是问题,我们是否应该将所有用户放在一个大表中?
最佳答案
有两种不同的方法可以解决这个问题。一种称为“单表继承”。这基本上就是您征求意见的设计。它非常快,因为没有连接。然而,NULL 可能会在很小的程度上影响吞吐量,因为与较薄的行相比,较胖的行需要更长的时间才能进入内存。
另一种设计称为“类表继承”。在这个设计中,父类(super class)一张表,每个子类一张表。非键属性进入它们所属的表。通常,一种称为“共享主键”的设计可以与此设计一起使用。在共享主键中,子类表的键id是父类表中相应行的id的副本。
这在插入时需要做一些工作,但是当您去连接数据时它会收回成本。
您应该在 SO(它们有自己的标签)或网络上查找所有这三个。您将获得有关设计的更多详细信息,并了解每种设计与您的案例的匹配程度。
关于mysql - 不同角色用户的最佳表结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13660154/
抱歉,问题标题含糊不清!我有一个 ASP.NET 应用程序,可与其他第三方软件配合使用(Burning Glass - 通过 tcp/ip 连接到 Web 应用程序,需要 - 正确配置的 dns 条目
我正在开展一个项目,将一个大型网站分解为更小、更具体的网站。我需要能够将对这些网站的访问限制为仅具有必要权限的用户,并且希望尽可能利用现有的成员资格/角色数据模型。 因此,理想情况下,我想将潜在的多个
抱歉,问题标题含糊不清!我有一个 ASP.NET 应用程序,可与其他第三方软件配合使用(Burning Glass - 通过 tcp/ip 连接到 Web 应用程序,需要 - 正确配置的 dns 条目
我对 FOSUserBundle 中的角色有点困惑。用户实体也有角色列,我们可以通过它为用户分配多个角色。根据发布在 Managing users/roles/groups in FOSUserBun
原谅我的新手问题,但我想按顺序执行三个任务并在剧本中使用两个角色: 任务 角色 任务 角色 任务 这是我到目前为止(任务,角色,任务): --- - name: Task Role Task ho
在触发器中,我想检查哪些角色对 USER() 有效,而不是 CURRENT_USER()。(认识到 CURRENT_USER() 返回触发器的 DEFINER)。 是否有任何类型的 USER_ROLE
我有一套Ansible playbooks 和主要的 yml 文件是这样的 - hosts: all roles: - common - install_nginx 我想在触发剧本
因此,我有以下代码输出安装的所有功能和角色: Import-Module ServerManager $Arr = Get-WindowsFeature | Where-Object {$_.Inst
我已经寻找了一段时间,并且已经手动完成了角色和权限的许多部署,但是有什么方法可以在Sitecore中为角色/权限创建一个程序包(或等效程序包)? 当您没有选择从一个环境到另一个环境进行完全部署时,使用
我想找到或创建一个与所有者或至少贡献者具有相同功能的 azure 角色。但此角色不应该有权创建 azure 资源。 我一直在浏览现有的预定义角色。 最佳答案 这在 Azure RBAC 上下文中没有任
我在文档中找不到答案,也找不到示例:是否可以在 role/defaults/ 中命名除 main.yml 之外的文件?我的意思是,main.yml 是具有默认值的文件的唯一有效名称吗? 最佳答案 根据
我尝试了kubectl get sa default命令,但只看到一些非常基本的值。在k8s中查看与特定服务帐户关联的权限/角色的命令是什么? 最佳答案 以下命令可能会有所帮助。它基本上获得RoleB
有没有办法告诉 Spring 在我制作的自定义用户 bean 中找到用户的角色? http://static.springsource.org/sprin...ns-config.html 因此,如果
在我的 playbook 中运行几次 Play 后,我想验证我的应用程序的部署。 在我的角色之一中,我有以下任务,将创建的 ec2 实例添加到“已启动”的主机: - name: Add new ins
我按如下方式将用户添加到角色(请注意,我在我的机器上运行下面显示的代码): Roles.AddUserToRole(oMU.UserName, "Role1"); 使用以下代码我检查用户是否在
我目前在为 postgresql 创建角色时遇到问题,这是我已经做过的,但自昨晚以来取得了任何进展 simplybel@simplybel:~$ sudo -u postgres createuser
一个项目现在有超过 200 个类,每个文件一个类,将它们划分到目录中似乎是恰当的。现在我正在考虑两种不同的策略; a) 按角色或层分组 repositories/ UserRepository
您如何为用户、角色和应用特定实体提供种子?似乎 IdentityModel 以它自己的上下文为目标? internal sealed class Configuration : DbMigration
摩尔庄园手游在六一儿童节上线之后,网上的争议声还是很多的,有夸赞的,称其找回了童年的回忆,也有吐槽的,觉得3d的设计很晕,没有以前的感觉,想要删除账号,那么大家知道怎么去注销吗,步骤流程是什么样的?
在 XP SP2 虚拟机中运行 Oracle 11gR1。完全披露:这是一项任务。 我试图在用户被授予 DBA 角色时进行审计,并在事件发生时发送电子邮件。 我相信命令 AUDIT DBA;将审核对
我是一名优秀的程序员,十分优秀!