概念数据模型CDM

概念数据模型是设计数据库不可或缺的一步,是整个数据库设计的关键,CDM的主要作用如下:

1)能够真实地模拟真实世界,是需求分析人员和数据库设计人员沟通的桥梁。
2)将系统需求分析得到的用户需求抽象为信息结构过程。
3)是后续逻辑数据模型和物理数据模型的基础。


CDM的基本术语:

1.实体:实体(entity)是指现实世界中的客观存在,对应现实世界中可相互区别的“事件”或“事物”。它可以是具体的对象,如“餐饮在线点评系统”中的会员、餐厅等,也可以是抽象的事件,如团购活动、一次手术等。

2.属性:每个实体都包括一组用来描述实体特性的属性(attribute)。例如,会员实体有会员编号、姓名、性别、出生年月、联系电话、联系地址、E-mail等属性。餐厅实体有餐厅编号、餐厅名称、餐厅简介、经营范围、餐厅描述、所属菜系、地址、联系电话和营业时间等属性。

3.标识符:标识符(identifier)是使用实体中的一到多个实体属性的值,唯一地标识实体的每一条记录。每个实体至少包括一个标识符,如果一个实体只有一个标识符,这个标识符一般默认用来作为主键。

4.联系:两个实体类型之间的联系称为实体联系,如特色菜与餐厅之间的关系。实体之间的关系一般分为以下几种类型:

一对一联系(1:1),

一对多联系(1:n)和多对一联系(n:1),

多对多联系(n:n),

强制/非强制联系(Mandatory/Dependant),

递归联系,

5.关联和关联连接:关联(Association)就是实体型的一种特例,用来在建模的时候更确切的表达实体间的关联信息。例如录音带、顾客、商店三个实体类型在租借录音带这个场景上发生关联,可把租借定义为上述三个实体类型之间的Association的实例。

6.继承:继承允许定义一个或多个实体是某个通用实体的特例,例如,“餐厅企业”是“企业”的特例,“企业”和“餐厅企业”存在父子关系。

7.数据项:数据项(data item)是信息的最小分片,它表示信息系统的一个事实或一个定义,它可能在一个模型对象中存在,也可能不存在。可以将一个数据项关联到CDM的一个实体,用来产生一个实体属性。  

8.域:域(domain)是一组具有相同数据类型值的集合。例如,性别{“男”、“女”和“保密”},启停状态(0,1)等,都可以作为域。域定义后能被多个数据项或实体属性共享。由于对同一个数据项引用的所有实体属性或数据项具有相同的数据类型(data type)、长度(length)、精度(precision)、检查参数(standard checks)、业务规则(rules)和强制/非强制(mandatory)等特性,所以更加容易使某些属性标准化,也便于统一修改。例如,要将性别的“男”、“女”和“保密”修改为“0”、“1”和“2”等情况。


创建CDM

选择“File”→“New”菜单项,从弹出的新建模型窗口中选择“Model types”→“Conceptual Data Model”→“Conceptual Diagram”,或者在新建模型窗口中选择“Categor-ies”→“Information”→“Conceptual Data”。

“Model type”区域选择模型类型,“Diagram”区域表示概念模型下只有一种图形,“Model name”用于设置概念模型的名称,如“概念数据模型简单实例”。

编辑CDM

参考:

概念数据模型CDM基础的更多相关文章

  1. PowerDesigner概念数据模型 CDM

    目标:本文主要介绍PowerDesigner中概念数据模型 CDM的基本概念. 一.概念数据模型概述数据模型是现实世界中数据特征的抽象.数据模型应该满足三个方面的要求:1)能够比较真实地模拟现实世界2 ...

  2. 物理数据模型(PDM)->概念数据模型 (CDM)->面向对象模型 (OOM):适用于已经设计好数据库表结构了。

    物理数据模型(PDM)->概念数据模型 (CDM)->面向对象模型 (OOM):适用于已经设计好数据库表结构了.   步骤如下: 一.反向生成物理数据模型PDM 开发环境 PowerDes ...

  3. PowerDesigner 概念数据模型(CDM)

    大   中   小 PowerDesigner 概念数据模型(CDM) 说明 2014-05-07  大数据深...  来源  阅 51   转藏到我的图书馆   微信 分享: QQ空间 QQ好友 新 ...

  4. PowerDesigner(五)-概念数据模型(CDM生成LDM,PDM和OOM)(转)

    概念数据模型 概念数据模型(Conceptual Data Model,CDM):表达的是数据整体逻辑结构,该结构独立于任何软件和数据存储结构,即它只是系统分析人员,应用程序设计人员,维护人员和用户之 ...

  5. PowerDesigner(五)-概念数据模型(CDM生成LDM,PDM和OOM)

    概念数据模型 概念数据模型(Conceptual Data Model,CDM):表达的是数据整体逻辑结构,该结构独立于任何软件和数据存储结构,即它只是系统分析人员,应用程序设计人员,维护人员和用户之 ...

  6. 五、概念数据模型(CDM生成LDM,PDM和OOM)

      概念数据模型 概念数据模型(Conceptual Data Model,CDM):表达的是数据整体逻辑结构,该结构独立于任何软件和数据存储结构,即它只是系统分析人员,应用程序设计人员,维护人员和用 ...

  7. PowerDesigner 概念数据模型(CDM) 说明

        ref: https://blog.csdn.net/tianlesoftware/article/details/6871179 关于PowerDesigner的说明参考: PowerDes ...

  8. PowerDesigner教程系列(一)概念数据模型

    目标: 本文主要介绍PowerDesigner中概念数据模型 CDM的基本概念. 一.概念数据模型概述 数据模型是现实世界中数据特征的抽象.数据模型应该满足三个方面的要求:1)能够比较真实地模拟现实世 ...

  9. PowerDesigner 概念数据模型

    (转自:http://www.cnblogs.com/yxonline/archive/2007/04/09/705479.html) 目标:本文主要介绍PowerDesigner中概念数据模型 CD ...

随机推荐

  1. H5 59-浮动元素的脱标

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. [iOS]改变UIAlertController的标题、内容的字体和颜色

    https://www.jianshu.com/p/51949eec2e9c 2016.03.23 22:36* 字数 272 阅读 37401评论 54喜欢 72 在开发中,弹出框是必不可少的,通常 ...

  3. Ajax中文乱码的解决

    网上有很多解决Ajax中文乱码的例子,昨晚弄了很久,最终确定一种“确实”有效地方法.首先我有必要说明一下我遇到的情况:有一个注册页面,注册用户填完信息并提交后,页面获得信息并通过java servle ...

  4. CI框架在模型中切换读写库和读写库

    如果你想在控制器中切换在application/config/database.php中配置好的数据库group,那么你可以参考这篇博客:CI框架在控制器中切换读写库和读写库 如果你是希望在模型中切换 ...

  5. Oracle创建'数据库'三步走

    --创建表空间 create tablespace waterboss datafile 'd:\waterboss.dbf' size 100m autoextend on next 10m; -- ...

  6. webservice服务的提供及调用完整代码示例

    服务提供方: applicationContext.xml applicationContext-webService.xml  服务调用方:

  7. spring后置处理器BeanPostProcessor

    BeanPostProcessor的作用是在调用初始化方法的前后添加一些逻辑,这里初始化方法是指在配置文件中配置init-method,或者实现了InitializingBean接口的afterPro ...

  8. Day 4-5 序列化 json & pickle &shelve

    序列化: 序列化是指把内存里的数据类型转变成字符串,以使其能存储到硬盘或通过网络传输到远程,因为硬盘或网络传输时只能接受bytes. 反序列化: 把字符转成内存里的数据类型. 用于序列化的两个模块.他 ...

  9. Day 3-4 函数进阶

    1.名称空间 定义:Python使用叫做命名空间的东西来记录变量的轨迹.命名空间是一个 字典(dictionary) ,它的键就是变量名,它的值就是那些变量的值.是存放变量和值的内存地址的绑定关系的空 ...

  10. 解决.Net Mvc跨域请求问题

    针对ASP.NET MVC和ASP.NET Web API两种项目类型 1.针对ASP.NET MVC,只需要在web.config中添加如下的内容即可 <system.webServer> ...