数据库设计知识点
第1范示:行不能重复,列不可再分(列的值唯一)
第2范示:非主依赖
第3范示:非主独立 非主键列之间相互独立
数据建模步凑
1. 分析需求,画出用例图
2. 编写用例文本,设计界面原型,模拟功能性场景
3. 找实体
4. 识别实体的属性
5. 识别实体之间的关系(一对一,一对多,多对多)
6. 画出概念数据模型(ER图)
7. 将概念数据模型转化为物理数据模型(表格)
8. 根据范式修改物理数据模型继续重复5
对象建模步凑
1. 分析需求,画出用例图
2. 编写用例文本,设计界面原型,模拟功能性场景
3. 找出业务模型(领域对象)
4. 找关键性的名词和动词,识别类的属性和职责
5. 识别业务模型之间的关系(关联,依赖,组合,聚合,泛化,实现)
6. 将业务模型转化为概念数据模型,重复数据建模的3,4,5,6
ER中的实体和OO中的领域对象的区别:
1.
2.
3.
4.
总结:大致来说理论上我们提倡OO,提倡DDD,但是由于客观条件(整个国内软件环境,中小公司急功近利的心态,不注重扩展性和维护性,主管人员 设计人员思想陈旧,项目周期 成本限制)以及主观条件(程序员自身的素质 对OO的理解)的限制,因此很多情况下仍然使用DB建模或者打着DDD的幌子走DB的老路。不论如何,现在DDD的思想已经遍地开花,总的趋势是逐渐向OO,向DDD上靠拢。因此,处于这样的一个过度时期,既不能完全地以DB为中心设计,也不能完全地OO,而是应该结合2者,(类似中国特色的社会主义道路)取长补短。