gpt4 book ai didi

mysql - 在数据库中引用外键的更好方法

转载 作者:行者123 更新时间:2023-11-29 13:30:06 25 4
gpt4 key购买 nike

您能建议数据库优化的最佳实践吗?这是我的数据库架构,

group(id, name, status)
users(id, group_id, parent_id, username, password)

company(id, name, address, phone)
agent(id, agent_code, name, address, phone)

在此架构中,我有四种用户组: super 管理员、公司用户、代理用户和最终用户。

推荐每个实体(公司、代理商)的用户的最佳方式是什么?

我有两个选择

A.用户表中的外键为company_id和agent_id

users(id, group_id, parent_id, company_id, agent_id, username, password)

B.外键作为公司和代理表中的user_id

company(id, user_id, name, address, phone)
agent(id, user_id, agent_code, name, address, phone)

我使用mysql作为数据库并使用级联引用。当我删除公司/代理时,关联的用户将根据选项 A 自动删除。但如果是选项 B,我必须运行第二个查询来删除公司/代理的关联用户。那么你有什么建议???

更新:忘记提及 child 用户。公司/代理商的用户可以有子用户,由用户表中的parent_id引用。

最佳答案

选项 A 听起来不错。

示例:- 假设 100 个用户仅与 5 家公司关联,因此可以在单个查询中删除单个用户...

关于mysql - 在数据库中引用外键的更好方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19584376/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com