关系数据库的去规范化(Denormalization)设计

本文探讨了关系数据库的去规范化设计,旨在提升查询性能。内容包括合并一对一联系、复制非关键字属性、复制外键、处理多对多联系、引入重复组、创建抽取表和对关系进行分区等方法。去规范化虽然可能导致复杂性和更新速度下降,但在不常更新、频繁检索的场景下,可以有效减少连接操作,提高性能。同时,文章也讨论了去规范化带来的数据一致性维护挑战及解决方案。
摘要由CSDN通过智能技术生成

目的:提升性能
去规范化会使实现变得更加复杂
逆规范化通常会降低灵活性
逆规范化会加快检索的速度,但却会降低更新的速度。(对数据库不需要经常更新,频繁检索的应用更合适!)

合并一对一联系

如果两个关系之间的联系是一对一,并且经常被一起访问,很少单独访问其中的一个关系,那就应该考虑合并

在一对多联系中复制非关键字属性以减少连接操作

将父关系的一个或者多个非关键字属性复制到一对多联系的子关系,以减少连接操作
在这里插入图片描述
因复制而产生的一个相关问题是每当一个元组被插入、修改或者删除时,会带来维持数据一致性的额外开销
因复制所带来的存储开销问题:目前二级存储器的价格很便宜,已不是一个很重要的问题,但这并不意味着可以随意复制

使用查看表(lookup table)
在这里插入图片描述
为房产类型定义一个查看表PropertyType(父关系),并将表PropertyForRent (子关系)修改为右边形式

使用查看表的好处

  • 减小子关系的大小:代码类型type属性只占1 个字节
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值