最近逛书店发现一本数据建模的好书——《数据建模:分析与设计的工具和技巧》(Data Modeler's Workbench:Tools and Techniques for Analysis and Design),作者Steve Hoberman。粗读完一遍后,感觉这本书的确无愧于译者和国外专家们的盛赞:“这本书充满了对改进数据模型和设计有益的技术和技巧,并且它还极富阅读乐趣——一个了不起的结合!任何一个数据建模者都应该拥有一本Steve Hoberman的关于数据建模工具和技术的书。”7 n# H; Z, W& b/ V* N
$ U- P. i% Q) e
尽管我对自己所掌握的数据建模知识有一定的自负,读完该书后,还是获益良多。本着好书大家一起分享的想法,我把该书的每个章节的总结和技巧建议列出来,以方便手头暂时没有该书的朋友在数据建模时参考。该书所介绍的工具和模版可在作者的Web站点下载,地址是: # C- V, m2 M0 ~8 F" ^3 l www.wiley.com/compbooks/hoberman$ W/ _2 S* c* K/ J& | I
+ I$ S) @9 Y# l9 l9 Z& G+ H
第一章:使用趣闻、类比和演示文稿来阐明数据建模的概念 " H" b, D$ C) o6 \; B- h$ w ( n% a* i0 Y. r! T/ J 在一般的日常沟通中。我们可能会说出并听到许多故事、或者趣闻这些故事涉及的论题范围很大。有些例子是周末发生在我们自己身边的事情,或者是与我们的工作项目有关的经历。这些趣闻有助于加强我们和周围人们的关系,增进我们的愉悦情绪,而且对我们有教育作用。我们能够把由语言表达出来的东西形象化。有时,当故事结束时,给我们留下的是以前未曾想到的信息或更多的认识。在解释数据建模概念时,趣闻是极其有效的。原因有如下几个: . i9 M# ~( P b0 c; c E. | 它们建立起持久的形象。" a2 ^! s. M1 V: {, e w S
它们引人入胜、使人愉悦。! x f& N1 D4 L7 B) P$ R4 n# t
它们增经人们之间的关系。8 Y/ B2 e, b6 r T
它们减缓压力。1 Q' R: R4 C& x' ~2 k) q0 b1 V! @5 d& S' W
3 s/ v# X4 X* n9 Z7 Y3 c4 N 成功编造并讲述一个数据建模方面的趣闻有下面三个简单的步骤:) [- C) S3 ?; J- \" q L
1)定义一个论题。要在心中保证,你讲述的这个趣闻有一个特定的目标或论题,也就是说,这个故事是为了解释一个数据建模的概念或术语。5 u) ~+ G' K; t' N
2)选择你的故事。我们可以选择的故事类型多种多样。我们要考虑选择一个有趣并有益,而且能够明白无误地传达主题意图的简短的故事。% a: J# u. z8 M0 y6 ^3 T! ?3 \0 Y
3)演练你的故事。一旦找到了合适的故事,你要好好演练一番,直到你自信它能够在两分钟的时间内充分表达你的论题。要避免讲述拖拖拉拉的故事。" F6 Y" B4 f: ]: u* |0 k: ^. S
1 J& k+ T9 ]/ O8 S2 u) S
数据模型类比! N- R6 N- z$ y& Q* {0 l& _
类比就是把两个或多个概念进行相互比较,以强调它们之间的相似或差异。类比是介绍外来事物或新鲜事物的一个很好的技巧,尤其是向非计算机专业的人士介绍计算机的专业知识时。Hoberman在数据建模中最常见的几个类比如下(他用这些类比轻松的打动管理层给他涨了一倍的工资^_^): x" Y5 U* C/ \, r, ?2 X 主体域模型是一个居高临下的视点。. @2 T+ T0 Q- j* A' C
数据模型是一个设计图。 - r# r8 D: r' V. \- x# R& Y& ` 企业模型是一个世界地图。2 R# K K6 K8 ]/ E( J
标准就是城市规划。% X, |! d6 o- h! A- F3 ~
元数据仓储库是一个图书馆。 9 i: I, V; o Y% p9 U% T- Q 数据仓库是“心脏”。 $ _" m( v2 D* m Z2 ^4 q, n% I2 J1 S% ?# ^/ B+ `$ L' u
第二章:元数据宾果游戏) l/ s8 N8 Q8 F- z! R' Q
简单来说,即通过宾果卡片游戏的方式,调动项目团队成员的积极性,来确定数据模型,并确定元数据的有效性。元数据宾果游戏强调“共赢”,如果运气好,游戏结束时每个人都能赢。 * K4 C) v( J* \+ u5 j3 W2 H: W# C- f$ S/ `- J
第三章:确保高质量的定义 - r+ [7 I3 T, |/ p# _$ M 本章集中讨论一个被称为“定义检查单”(Definition Checklist)的工具,它包含了确保定义的质量处于最高水平的准则。 ; }% @0 _0 P: N% v1 k. g! o6 K& Z9 | g8 B
第四章:数据建模者的项目计划 `) d0 ^2 V: K' Y4 u$ \7 I
本章重点介绍确定数据建模阶段、任务、工具和时限的四个工具:& {3 j9 B/ [3 `, U& g" K7 T! z/ f
·数据建模阶段的工具:用来确定最高层次上的数据建模步骤。 & ]* u0 x% [) V! z Q1 e1 } ·阶段—任务—工具:提取出“数据建模阶段”的各个阶段并把他们分解成数据建模任务。 # l. V3 y) ` @ ·优先级三角形:你可以从以下三项中取两项极值:很高的质量、最短的时间与最低的成本,但你永远也别想三者兼得。 / ]; C5 `3 j2 m ·可靠的估算工具:“主体域工作量时限”根据应用程序的类型,确定每个数据建模阶段应占整个项目的百分比。“任务工作量工具”提取在“阶段—任务—工具”中确定的每项任务,并列出它们应占整个数据建模工作产品的百分比。这两个工具的组合可使你向项目经理提供一份具有一定精确度的合理估算。9 G, e3 S1 p" k* q% B5 [$ X4 G1 p
9 r4 S% Q$ X4 F! U2 U# f 第五章:主体域分析+ a/ H( t- x$ H; i+ f$ Q5 f% K$ h3 f/ ~
本章主要探讨五个关键的工具,这五个工具对数据建模工作的主体域分析阶段有帮组作用。它们应该按照下面的顺序被逐个完成: $ M5 B$ {& Q9 s: t8 q 1)主体域检查单:新应用程序中的主体域的完整列表,还有各个主体域的定义和同义词(或别名)。6 e- C3 c& g* n3 K6 |! ?, I, N
2)主体域CRUD(Create Read Update Delete)矩阵:包含新应用程序和现有应用程序之间的主体域方面的差别和重复之处,确定应用程序的范围。+ j V* P8 q2 @. A/ }
3)In-the-Know模版:确定完成这个新应用程序的数据间模工作产品所需要的、被用作资源的人员和文档。 - K) c8 o/ t. z1 j$ t$ B 4)主体域家族树:包含每一个主体域的源应用程序和若干其他的关键信息,阐明主体域数据将来自哪里。 7 N! l8 X( M4 g; R$ @ 5)主体域力度矩阵:使用一个电子表格的格式,记录每一个度量和事实主体域的发布层次。 6 ~$ h, I7 }/ S3 a: L, H6 E2 Y' }7 _! O' F- P
第六章:主体域建模; m9 Z3 j7 |9 r/ \5 P5 p8 R
本章阐述三个队主体域信息进行建模的强大工具: ( B- [6 e6 ^ p1 @- G( Z6 h ·“业务清理板”模型。 - Q' N8 [7 B9 g1 \+ u1 ^& O ·“应用程序清理板”模型。5 d* B) ]3 c3 z/ ^" h; _8 o8 T
·“早期现实性检查”模型。+ z* Z& V" b) a) j$ `
, W( b2 L* z/ G% E4 P1 w6 G' q, Z$ f
第七章:逻辑数据分析9 q% y+ r" z2 K1 R4 b
本章关注四个逻辑数据分析工具,它们应该按照下面的次序被使用:& D; e8 `( i0 n3 h( {
1)数据元素家族树:包含应用程序的数据元素的完整列表,以及每个数据元素的来源和变换信息,还有其他几个关键的数据元素元数据。) t( _! @$ s9 h( ?9 y# c, {
2)数据元素粒度矩阵:用一个电子表格的格式,来记录每个度量和事实的发布层次。 & P% w9 C. C3 [: I% V2 ` 3)数据质量记录模板:展示每个数据元素的员数据和一些实际数据的对比。 4 ~0 K J3 X: C8 J1 X7 X 4)数据质量确认模板:记录每个数据元素的元数据和一些实际数据的对比的结果。 0 H1 A: s: _ c: Y - f+ p |! B% u- _8 Q- y 第八章:规范化之旅和反向规范化生存指南(强烈推荐:是我目前所读过最好的关系型数据库的规范化技术文档) & S8 B4 y7 h0 v+ x. N6 i0 X 规范化是一个剔除冗余并应用规则的过程,它的目的是为了更好的理解和表达存在于数据元素之间的依赖性和参与性。规范化包含6个层次,最高层是第五范式(5NF)。一般的技术文档上都认为达到3NF即可,Steve Hoberman给我们指明了更高的目标:5NF。Graeme Simsion写过一本名为《Data Modeling Essentials》的书,在这本书中,他写道:“较高层次的范式常被从业者误解并因此而被忽视,或为了支持不可靠的建模时间而被引用。”但是,我们需要理解这些较高层次的规范化,因为它们体现了额外的规范化机会,并帮组我们进一步减少冗余信息、改进设计的灵活性。尽管余下的三个规范化层次有可能仅仅产生次数很少的变化,但它们仍然具有一些提高灵活性和效率的机会。下面是BCNF&4NF&5NF的定义(比国内教材上罗列的数学公式容易理解得多^_^):' S; a9 o: w( D
BCNF=3NF+下面的规则:0 `! g' p6 ]* {6 c% B
每一个数据元素都完全依赖于键、整个键,而且除依赖于这个键以外,不依赖于任何其他数据元素。 ( L$ f& }" a; u 4NF=3NF+下面的规则: % o9 k2 v" i8 z% \" m 要把主键中拥有三个或更多外建数据元素、切割格外键之间不存在约束的那些实体分解成两个或更多个实体。 ' e; M! U" j0 y% q' I# a9 T 5NF=4NF+下面的规则: ( O; M: n5 x( r1 j' M 把主键中拥有三个或更多的外键数据元素,且这些外键数据元素之间存在着约束的实体分解成为所有的约束都需要的多对多的关系。. D6 |5 r$ w( y C# h& x$ e6 K0 h- E
A5 M# E9 ?# c' n. ~, Q
当我们攀上5NF的顶峰后,再根据实际需求情况来进行“反向规范化”增加数据冗余,从而简化开发,提高查询速度。反向规范化是这样一个过程:在定义了一个可靠的、完全规范化了的数据结构之后,你借助这个过程,有选择地引入一些重复的数据,以促进特殊性能需求的实现。Steve Hoberman的“反向规范化生存指南”给如何适当增加冗余提供了一套可计算的评分标准。通过考察每个关系的6个问题,累加各个问题的得分之后,当得分大于等于10时,我们将对该关系进行反向规范化。 r5 x5 ]: s8 {8 l
, ?# b1 k1 x# ^. p* l( I" X
“反向规范化生存指南”的计分规则:: H2 x" s2 _0 _! _
1.关系是什么类型的:该问题确定我们所分析的关系的类型。父实体对于子实体具有什么样的关系?7 Z# q# R' |/ G
层次关系(20分)1 X1 N% y% k; Y: ` o, ~
同等关系(-10分) : p1 o4 Y2 b! p) {. }. Z# Q) M 确定关系(-20分)! A2 Z; ]" w" u* P( F5 |8 P
2.参与率是多少:该问题确定一个关系中的每个实体的参与性。换句话说,对于一个给定的父实体数值,大概会有几个子实体数值?父与子的关系越接近“一对一”,我们对它进行反向规范化的机会就越大。 8 |" Z3 T5 ~& E2 V9 r H 多达“一对五”的比率(20分)8 y! z% c5 q3 p
多达“一对一百”的比率(-10分)0 r5 E. \" W/ ]5 l, P8 g! M6 Z4 }- J
超过“一对一百”的比率(-20分) - ] {4 m: T5 m 3.父实体中有多少个数据元素' \. G5 W& R: l! `7 n+ R6 W
少于10个数据元素(20分) 7 H/ ?2 e8 O% \& o) K! t 数据元素的数量介于10到20之间(-10分) 5 s' Z$ o) T; {/ A" m: k5 g 多于20个数据元素(-20分) 1 i- ]+ s. X7 \ 4.使用率是多少:当用户需要来自子的信息时,通常情况下,它们是否还需要来自父的信息呢?换句话说,这两个实体的耦合或相关程度如何?' z- g3 ^# x% V: Q) y
相互之间的关联很强(30分) + u4 N9 _8 @8 n# Y. x 相互之间的关联较弱或者没有关联(-30分)% I% x+ p9 h, b3 H% _+ @+ e. p
5.父实体时一个占位符吗:在不远的将来,我们是否还打算向父实体加入更多的数据元素或关系?如果答案是“不”,那么进行反向规范化的可行性就更强。5 e7 `* j7 V+ u3 `' X c t) c
是(20分)+ a V. p/ u2 J& E
不(-20分) " U4 q- k+ c2 O7 o1 ]& ]" O 6.变动对比率是多少:该问题是为了确定,在同一时间周期内,两个实体的插入和更新的频度是否相近。如果其中一个实体很少变化,而另一个实体却变动频繁,那么,我们就非常倾向于保持它们的规范化状态,把它们放在各自的表中。3 z9 ~3 X: X8 a
相同(20分)" z: J- M- O( k$ o
不同(-20分) ' ^. C0 Z* T2 R% G6 s, `9 k ; J. H0 k4 K4 Z8 n' k+ Z9 D “反向规范化生存指南”的使用方法: * w; L& x. e' ^7 y( ^, J* r [: S 1)把模型中的关系按照优先级排序1 l2 u( e9 s. V* ?, X
2)选择一个关系 0 U4 v5 w5 s9 u7 i 3)对这个关系回答提问 , B9 F" G" y. t1 X0 f5 H+ Z 4)如果得分等于或大于10,就进行反向规范化5 N7 c% d& i% r& {2 w# r
5)返回步骤二,直到完成所有的关系。# e/ }( ?: W/ g) x8 m7 E
: D; ^% |9 S* h( y) C9 y. ?
第九章:抽象化安全指南和组件 8 k# Z1 @" M* x2 f9 Z 看过我的“浅谈数据库设计技巧(上) ”的朋友应该还记得我举的第二个例子:网上电子商务平台上的商品信息表的设计。本章将我在上面例子中所用的方法上升到了理论阶段,采用了面向对象的设计,将所有商品的共有属性提取出来,抽象成一个超类,再加入一个表来记录各个不同实体之间的细节来实现超类的派生,从而实现设计的灵活性。当出现下面两种条件的任何场合,抽象化都是极其有用的: * o; F! L8 m. w: i4 H( i; x. K 设计需要永久维持下去:要求以后尽可能的不修改数据库设计 6 n% v+ C$ A, S6 t 需求可能发生变化:应用程序的需求发生变化,而要求业务流程重组或进行功能升级. K T7 a7 I3 Q, Y
数据仓库:当新的分类类型从源应用程序中传过来时,我们无须对数据仓库的设计进行任何改动,而只需在分类类型实体加入一个新行即可 - x0 U7 O' ~1 g7 y7 z 元数据仓储库:和数据仓库的要求类似( `! ~" K; E& P; n W7 h
4 f- P( G/ N0 A2 U' L/ l# l* c6 f8 S
当然,抽象化会大大增加工作量和开发的复杂度,而人们通常关注的是非常短期的应用和眼前的成本,而不关心将来的高得多的成本。所以,我非常赞同敏捷软件开发这个观点:在最初几乎不进行预先设计,但是一旦需求发生变化,此时作为一名追求卓越的程序员,应该从头审查整个架构设计,在此次修改中设计出能够满足日后类似修改的系统架构。* H7 Z+ A! y7 c9 E% }
2 w' y. h0 O3 N6 K. n- i6 A- Z
“抽象组件”就是小型的抽象模型片段,在许多的建模场合(无论是什么行业、组织,甚至什么主体域的建模场合)中,它们都可被反复使用。在键模阶段多次使用抽象化之后,你将开始看到出现的抽象化结构的趋势。这些“抽象组件”有如下的目的:0 G1 z, ^% \! z
加快设计速度" o9 U$ d! e4 K, v- ]$ i' O
加快开发速度 . G6 g! r& s$ e* K 提供通用且有用的机构 W8 p& y, F' Z- @: A: H
: g' L% O! t: p( J$ O 第十章:数据模型美化技巧 1 N2 @$ p4 \+ C& x. `" g5 J0 [& K4 k9 y 本章通过关注如何改进逻辑和物理数据模型的视觉外观,使我们的设计超越直接的应用程序需求。本章中讨论了五个类别的美化技巧: 3 ?! ]; D* z; M1 V. m 逻辑数据元素排列技巧:这些技巧是一个推荐的、对你的逻辑数据模型中的每一个实体的数据元素进行排序的方法。 : w8 J& M4 i5 c V- u9 b 物理数据元素排序技巧:这些技巧关注数据模型中每一个实体的最佳布局。 ) l& y) F- `1 g* S$ d 实体布局技巧:这些技巧关注数据模型中的每一个实体的最佳布局 ; ~7 L& A$ t: Z* L 关系布局技巧:这些技巧关注如何调整重叠的关系线条以及看起来穿越(而不是绕过)无关实体的关系 ! V- j8 F$ G; M& i9 d* D# k8 v) V+ n 吸引注意力的技巧:这些技巧关注如何在我们的涉及中突出的某些元素、实体或关系。! q, o3 _: K: \2 c# f
5 Q/ R# d+ M2 R5 ~
第十一章:规划一个长盛不衰的数据建模生涯' L! b d# C/ B8 Q' G1 x v
对数据建模者的十大忠告清单: , Z9 f; V6 n* @: B1 Z( N 1)记住:灵活性、准确性和背景 1 j6 U4 Q- a8 J2 J4 n! P 2)建模只是你的工作的一小部分7 B( x. K4 d. v0 w
3)尝试其他角色& g0 A- F& D3 s0 G, b/ y" I {
4)了解95/5规则:95%的时间将花费在5%的数据元素上, @9 o1 l) {) T6 ~7 u3 T4 s
5)数据建模从不令人厌烦:如果你一直在做数据建模工作,而且发现自己经常感到厌烦,那么,你的确该改变一下了。这可能不是数据建模领域本身令人厌烦,而是你所在的特定的任务、公司或行业不再令人兴奋。冒险一下,尝试着道一个不同的项目或行业中进行数据建模工作吧!6 j0 x! T/ o2 i
6)站在技术前沿% `3 B, b. Z4 U6 T/ k5 p
7)尽量不要在模型上牵扯感情因素:建模者必须理解,人们在评审过程中的意见并不是针对模型的创建者,而是针对这个模型的内容。即那句老话:对事不对人。 U5 c: K+ Q1 t0 d% k: }0 f
8)让你的创造力展开翅膀:在考虑记录数据需求和改进设计的新方法时,要紧可能有创造性。有创造性也许就意味着修改本书中的某些工具。这还可能意味着提出你自己的电子表格或其他工具。" o& U# U5 w9 @8 u* f* X$ F, w
9)单纯的理论太昂贵了:在设计活动过程中,你要确保把这个观点牢记在心。为这个应用程序掏腰包的部门和组织期望看到的是能看得着的实用结果。' D0 G, N0 H4 c. }6 R8 F- Q" G
10)成为一个了不起的会讲故事的人:作为一名数据建模者,讲故事是工作的一个很重要的部分。为了帮组教化和影响项目经理以及对我们行业缺乏理解的其他人,我们需要讲故事或趣闻。 + D5 v; x) s1 p- |7 {: D" U4 x0 c/ m# {" N1 z* L: A
最后,我个人觉得,Steve Hoberman所提出的“抽象组件”的观念和面向对象设计中的的“设计模式”非常类似。即数据库专家在多次的数据建模后,将各个项目中的类似部分抽象化,提取出特定的建模模型片段,以后只需在新的项目中对这些模型片段细化派生,即可快速构建出适合于该项目的数据库架构。不过,这些建模模型片段并没有统一,形成标准,目前也没有出版这类的书籍。本人正在陆续总结自己在这方面的经验,但是自知水平有限,不敢在高人面前班门弄斧,只希望自己日后陆续发布的相关文章能起到抛转引玉的作用,争取由中国的程序员率先统一出数据建模领域的“设计模式”。