书籍详情

数据库重构

数据库重构

作者:(加)安布勒(Ambler,S.W.),(美)塞得拉吉(Sadalage,P.J.) 著,王海鹏 译

出版社:机械工业出版社

出版时间:2007-01-01

ISBN:9787111202097

定价:¥32.00

购买这本书可以去
内容简介
  本书首次专门讨论数据库重构,向数据专业人员展示了如何运用重构、测试驱动及其他敏捷技术进行演进式数据库开发。书中通过许多实际例子,详细说明了数据库重构的过程、策略以及部署。.本书前5章介绍了演进式数据库开发的基本思想和技术,后6章详细描述了每一类重构,包括结构、数据质量、参照完整性、架构、方法的重构;另外还描述了不属于重构范畴的转换技术。书中的示例代码是用Java、Hibernate和Oracle代码编写的,代码都很简单,读者可以毫无困难地将它们转换成C#、C++或Visual Basic代码。重构的价值是毋庸置疑的,这已在许多项目中证明了。重构能帮助软件专业人士改进系统设计及其可维护性、可扩展性和性能。本书首次介绍了专门针对数据库系统设计的强大的重构技术。作者向读者充分展示了:对表结构、数据、存储过程和触发器的小小改动就能在很大程度上改进数据库的设计,同时又不改变语义。读者还将学到分步演进数据库模式以及源代码的方法,使依赖迭代、敏捷方法开发的项目变得更高效。..本书为数据库重构提供了全面的指导和参考,介绍了数据库重构的基本概念,帮助读者克服重构真实数据库系统时的实践障碍。通过完整的例子,作者展示了重构简单的单个数据库应用和复杂的多个应用的情况。通过本书,读者可以掌握重构数据库模式所涉及的各项任务,学习在最复杂的产品环境中部署重构的最佳实践。本书系统介绍了5类主要的数据库重构技术。读者将看到如何利用重构来增强数据库结构、数据质量和参照完整性,以及如何对架构和方法进行重构。本书提供了大量的基于Oracle和Java的例子,读者可以很方便地调整到其他语言,如C#、C++或VB.NET,或其他数据库,如DB2、SQLServer、MySQL和Sybase。利用本书提供的技术和例子,读者在进行数据库重构时可以减少浪费和风险,避免返工并节约成本,可以平滑地演进数据库系统,延长数据库的使用寿命。...
作者简介
  Scott W.Ambler国际知名的软件过程改进顾问,技术领头人,敏捷建模、敏捷数据、企业统一过程、敏捷统一过程方法学的创始人。Scott经常在Software DeveloPment、JavaOne、OOPSLA和DAMA等会议上进行主题演讲,他写作(或与人合著)出版的书还包括《Agile Modeling》、《Agile DatabaseTeehnique》、《The Obieet Primer,ThirdEdition》、《The Elements of UML UML 2.0 Style》和《TheEnterPrise Unified Process》等。Pramod J.Sadalage Thoughtworks公司的顾问。在1999年用Xp方法开发一个大型J2EE应用时,他就率先实践了演进式数据库设计和数据库重构的过程。他目前正在进行有关演进式项目中的数据库管理以及在数据库设计和管理中使用演进式过程等主题的写作和演讲。
目录
对本书的赞誉序前言致谢第1章 演进式数据库开发 1.1 数据库重构 1.2 演进式数据库建模 1.3 数据库回归测试 1.4 数据库工件的配置管理 1.5 开发者沙盒 1.6 演进式数据库开发技术的障碍 1.7 本章小结第2章 数据库重构 2.1 代码重构 2.2 数据库重构 2.2.1 单应用数据库环境 2.2.2 多应用数据库环境 2.2.3 保持语义 2.3 数据库重构的分类 2.4 数据库味道 2.5 数据库重构在开发中的位置 2.6 使数据库schema的重构更容易 2.7 本章小结第3章 数据库重构过程 3.1 验证数据库重构是否合适 3.2 选择最合适的数据库重构 3.3 让原来的数据库schema过时 3.4 前测试、中测试和后测试 3.4.1 测试数据库schema 3.4.2 检验数据迁移的有效性 3.4.3 测试外部访问程序 3.5 修改数据库schema 3.6 迁移源数据 3.7 重构外部访问程序 3.8 运行回归测试 3.9 对工作进行版本控制 3.10 宣布此次重构 3.11 本章小结第4章 部署到生产环境 4.1 在沙盒之间有效地部署 4.2 采用数据库重构包 4.3 制定部署时间窗口进度计划 4.4 部署系统 4.5 移除已过时的schema 4.6 本章小结第5章 数据库重构策略 5.1 小的变更更容易进行 5.2 唯一地标识每一次重构 5.3 通过许多小变更实现一次大变更 5.4 建立数据库配置表 5.5 触发器优于视图或批量同步 5.6 选择一个足够长的转换期 5.7 简化数据库变更控制委员会策略 5.8 简化与其他团队的协商 5.9 封装对数据库的访问 5.10 能够容易地建立数据库环境 5.11 不要复制SQL 5.12 将数据库资产置于变更控制之下 5.13 注意机构中的政治斗争 5.14 本章小结 5.15 在线资源第6章 结构重构 6.1 实现结构重构时的常见问题 6.2 删除列 6.3 删除表 6.4 删除视图 6.5 引入计算列 6.6 引入替代键 6.7 合并列 6.8 合并表 6.9 移动列 6.10 列改名 6.11 表改名 6.12 视图改名 6.13 用表取代LOB 6.14 取代列 6.15 用关联表取代一对多关系 6.16 用自然键取代替代键 6.17 拆分列 6.18 拆分表第7章 数据质量重构 7.1 实现数据质量重构时的常见问题 7.2 增加查找表 7.3 采用标准代码 7.4 采用标准类型 7.5 统一主键策略 7.6 删除列约束 7.7 删除缺省值 7.8 删除不可空约束 7.9 引入列约束 7.10 引入通用格式 7.11 引入缺省值 7.12 使列不可空 7.13 移动数据 7.14 用属性标识取代类型代码第8章 参照完整性重构 8.1 增加外键约束 8.2 为计算列增加触发器 8.3 删除外键约束 8.4 引入层叠删除 8.5 引入硬删除 8.6 引入软删除 8.7 为历史数据引入触发器第9章 架构重构 9.1 增加CRUD方法 9.2 增加镜像表 9.3 增加读取方法 9.4 用视图封装表 9.5 引入计算方法 9.6 引入索引 9.7 引入只读表 9.8 从数据库中移出方法 9.9 将方法移至数据库 9.10 用视图取代方法 9.11 用方法取代视图 9.12 使用正式数据源第10章 方法重构 10.1 接口变更重构 10.1.1 增加参数 10.1.2 方法参数化 10.1.3 删除参数 10.1.4 方法改名 10.1.5 参数重排序 10.1.6 用明确的方法取代参数 10.2 内部重构 10.2.1 合并条件表达式 10.2.2 分解条件 10.2.3 提取方法 10.2.4 引入变量 10.2.5 删除控制标记 10.2.6 消除中间人 10.2.7 参数改名 10.2.8 用表查找取代文字常量 10.2.9 用条件短语取代嵌套条件 10.2.10 拆分临时变量 10.2.11 替换算法第11章 转换 11.1 插入数据 11.2 引入新列 11.3 引入新表 11.4 引入视图 11.5 更新数据附录 UML数据建模表示法词汇表参考文献和推荐读物重构和转换列表
猜您喜欢

读书导航