数据库重构六类问题及策略:味道、多用途、重复数据与封装
139 浏览量
更新于2024-08-28
收藏 255KB PDF 举报
本文档深入探讨了数据库重构的重要性及其常见的问题类型,借鉴了代码重构的概念,将数据库中可能出现的问题称为“数据库味道”。文章列举了六种主要的数据库重构类别:
1. 多用途的列:当一个列承担多种职责时,可能导致代码冗余,需要额外的逻辑来确保数据的一致性。例如,一个列可能既要存储个人的生日,又要在某些情况下记录入职日期。
2. 多用途的表:设计中存在表的功能混乱,如Customer表用于存储人和公司的信息,这表明表的设计可能不够明确,需要重新考虑实体关系。
3. 重复的数据:在操作型数据库中,数据冗余可能导致一致性问题,当数据在多个表或位置出现时,更新管理变得复杂。
4. 列太多的表:过多的列意味着表的内聚性差,例如Customer表包含多个地址和电话,这种情况下应考虑将数据分解到专门的表中,提高数据结构的清晰度。
5. “智能”列:包含隐含信息的列,如客户ID的前几位代表开户行,这类列在查询时需要解析,增加了复杂性,需要重构以提高数据的可读性和易管理性。
6. 数据库重构:作为数据库实现技术,数据库重构涉及对数据库模式进行调整,以便于添加新功能,遵循演进式或敏捷的数据建模方法。在复杂的多应用环境中,重构难度增大,因此通常通过封装数据库访问,比如使用数据访问对象(DAO)或其他持久层技术,来降低不同组件间的耦合。
本文提供了对数据库重构全面的理解,包括问题识别、分类以及如何在实际项目中实施,强调了在数据库设计中保持良好的结构和模块化的重要性,以支持系统的长期稳定性和可维护性。
点击了解资源详情
点击了解资源详情
点击了解资源详情
2019-05-24 上传
2021-02-13 上传
点击了解资源详情
点击了解资源详情
点击了解资源详情
点击了解资源详情
weixin_38678550
- 粉丝: 3
- 资源: 955
最新资源
- BottleJS快速入门:演示JavaScript依赖注入优势
- vConsole插件使用教程:输出与复制日志文件
- Node.js v12.7.0版本发布 - 适合高性能Web服务器与网络应用
- Android中实现图片的双指和双击缩放功能
- Anum Pinki英语至乌尔都语开源词典:23000词汇会话
- 三菱电机SLIMDIP智能功率模块在变频洗衣机的应用分析
- 用JavaScript实现的剪刀石头布游戏指南
- Node.js v12.22.1版发布 - 跨平台JavaScript环境新选择
- Infix修复发布:探索新的中缀处理方式
- 罕见疾病酶替代疗法药物非临床研究指导原则报告
- Node.js v10.20.0 版本发布,性能卓越的服务器端JavaScript
- hap-java-client:Java实现的HAP客户端库解析
- Shreyas Satish的GitHub博客自动化静态站点技术解析
- vtomole个人博客网站建设与维护经验分享
- MEAN.JS全栈解决方案:打造MongoDB、Express、AngularJS和Node.js应用
- 东南大学网络空间安全学院复试代码解析