首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >构建一对多表php mysql的正确方法

构建一对多表php mysql的正确方法
EN

Stack Overflow用户
提问于 2018-05-05 18:52:37
回答 1查看 85关注 0票数 -1

假设我有一个用于法律领域的表lawareas,例如:

代码语言:javascript
复制
ID Area
1  Children Law
2  EU law
3  Crime

还有律师,但每个律师可以被分配到多个法律领域,所以表如下

代码语言:javascript
复制
ID Name Areas
1  John 1,3
2  Bob  2,3

这就是我现在做的方式,但它似乎是错误的。

有没有更好的方法来组织这些数据?

我想我可以有第三个表,上面两个表之间的关系如下:

代码语言:javascript
复制
AreaID LawyerID
1      1
3      1
2      2
3      2

哪一个更好,为什么,原始的选项对我来说似乎在各个方面都不那么麻烦?

EN

回答 1

Stack Overflow用户

发布于 2018-05-06 08:27:55

在第一个解决方案中,您通过字符串连接来表达数据语义。这有严重的缺点:

  • 查询数据会很麻烦(例如,获取所有执行刑事法律的律师)
  • 向律师添加和删除区域很麻烦(因为您必须进行字符串解析,而concatenation)
  • you必须自己注意数据一致性(例如,所有区域ids都必须存在于区域表中)

基本上,您失去了DBMS提供的所有功能,除了一般的数据存储和检索。你最终会得到可怕的应用程序代码,在那里你重新实现这个功能,糟糕的性能和最有可能的数据不一致。

让数据库做它能为你做的事情,但你必须满足它的结构需求。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50188637

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档