设计数据库表结构必须遵从 3 范式吗? 我感觉字段冗余更好用呀?冗余的字段也不超过 10 个

2022-03-12 15:02:32 +08:00
 kikione
3901 次点击
所在节点    程序员
26 条回复
RainCats
2022-03-12 15:03:23 +08:00
范式就是拿来打破的,冗余看情况
aristotll
2022-03-12 15:06:27 +08:00
一般第二范式就好了。冗余看业务场景
pendulum
2022-03-12 15:10:34 +08:00
个人项目喜欢 BCNF ,其他的随意
iseki
2022-03-12 15:12:38 +08:00
你想好万一出现修改该怎么办就好
chenxytw
2022-03-12 15:12:59 +08:00
看实际情况。最最常见的不遵守范式的理由就是更在意性能吞吐。
iseki
2022-03-12 15:19:35 +08:00
能不打破就别打破,但有时候也没办法
NCry
2022-03-12 15:27:51 +08:00
我的看法是只要你明确知道自己为什么需要冗余字段,并且考虑到了可能带来的问题,那么就可以不遵循。
dobelee
2022-03-12 15:30:44 +08:00
是范式,不是规范,更不是规定。实际情况大把冗余和快照以避免连表。
Chad0000
2022-03-12 15:56:02 +08:00
想想微服务,数据更冗余了
falsemask
2022-03-12 17:59:36 +08:00
可千万别,接手的一个项目完全按照第三范式规则来的,A-B-C-D-E-F ,从左到右都是一对多的映射,都是用一个 id 对应,到了 F 表,完全看不出来对应的 A 表的字段是啥了,每次查个数据,血压都高了
elboble
2022-03-12 18:05:12 +08:00
来 v2 时间不长,知道的月经讨论有两个,
sql 要不要物理外键,
http 除了 get,post 其他行为能不能用,

是否遵守范式可以算第三个吧。
Chad0000
2022-03-12 18:09:02 +08:00
@elboble 还有 win/mac android/iOS ,感觉这个都属于周经了。
LLaMA2
2022-03-12 18:40:57 +08:00
请先设计好数据结构,有了好的数据结构,ORM 会自动生成你想要的数据库,当然,性能问题可能不好,
但是有数据结构,代码写的飞起,根本不在乎数据库里叫什么,怎么存的。
要是用 typescript 的 typeorm 。连 hibernat 里恶心的 nested object mapper 问题都没了。那开发速度更进一部,这样,你就有时间做自己想做的事情了
kingjpa
2022-03-12 22:17:37 +08:00
对于大厂为了性能,肯定能遵守最好了啊
对于我们外包仔,null text like 满天飞,
交付了事,规矩多就是给自己找不自在
glovebx
2022-03-12 22:19:21 +08:00
适当冗余,用空间换效率很划算
westoy
2022-03-12 22:19:54 +08:00
抛开业务类型和规模谈这个没意义啊
melkor
2022-03-12 23:02:53 +08:00
@falsemask 写个类把这逻辑都封装起来呀
xuanbg
2022-03-12 23:48:12 +08:00
可以冗余的当然就要冗余,不然什么都联表查询效率就太低了。
huyi23
2022-03-13 00:20:24 +08:00
能冗余尽量冗余,一切为了不连表
huyi23
2022-03-13 00:22:27 +08:00
@huyi23 有一个前提,当前值基本不存在更新操作

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/839874

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX