用PowerDisigner建立一对一与多对多模型解析.doc

用PowerDisigner建立一对一与多对多模型解析.doc

  1. 1、本文档共14页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
一对一模型 身份证----------用户 建立模型之前首先得想一下要建立一对一的模型的思路,建立模型思路才是最重要的,思路想好了用工具很快就会生成。 一对一模型的建立有两种方式: 相同主键 (继承来实现,只继承主键) 唯一外键 :一对多的一种特殊形式(外键是unique) 1、 相同主键型的一对一模式 (1)先创建两个概念模型 身份证 用户 用户的概念模型中没有设置主键 (2)用inheritance,从用户模型连接到身份证模型 (3)双击设置继承关系,选择inherit only primary altributes,只继承主键属性,否则会把所有属性在用户里再显示 (4)tool--转换成物理模型 (5)Database--生成脚本文件,去掉check model(如果没有连接pl/sql就选script generation) (6)如果面板上还有其他模板,勾选掉 (7)接下来确定,就可以成功生成脚本文件了。。。 用生成的脚本文件在plsql的命令窗口运行,生成两个表,插入数据 先插入身份证 再插入用户表信息 想要在用户表中加入身份证号是3的用户就会出错。idnum既是用户表的主键又是用户表的外键。 2、 唯一外键型的一对一模型 (1)各自创建两个概念模型都有主键 (2)表A-------表B建立一对多关系 (3)转换为物理模型 (4)生成脚本文件 (5)在脚本文件里把有外键的一个表的外键加上unique约束 (6)在pl/sql中运行脚本文件生成的两个表就是一对一关系。 多对多模型 学生--------课程 要实现多对多的先想一下思路 1)建两个表学生表、课程表行吗?不行 2)需要再有一个新建表作为中间表,两个表都连在这个中间表上 这个中间表有两种实现方式: 组合主键:两者就是只建立关系是使用 新主键:除了建立关系还需存储一定量的数据时使用 这里只记录组合主键方式多对多实现 (1)创建两个模型 创建完大学生表模型后,再在课程里输入name自动出现了格式,因为前者中有name默认一样格式,不碍事 (2)添加Association_1作为中间表,双击 也可以在第二个页面添加这个关系的属性,比如成绩 (3)用Association_link连接 可见建立模型是简单的,重要的是多对多的思路,思路建立起来建立模型会很快。 (4)Tool-----转换为物理模型 (5)Database----生成脚本,去掉check model,勾上Upper 然后确定。生成脚本文件就成功了。 (6)在plsql中执行脚本文件生成表,插入数据 关系表中组成主键的两列只能插入另外两个表中有的,实现了一个人可以选多门课,一门课可以被多个人选 到了这里可以在像一种情况,一个学生一学期学了一门课,修了一个分数,又一学期又要选这门课, 这样的多对多就有不能完成了,因为上面的组合主键在一个关系表里只能出现一次,即一个学生只能选同一 门课一次,当然会想到再在关系别种增加一列学年列使三列一起组成主键,但这样会有些乱,我们可以在创 建一个成绩表,与学生和课程建立关系 这样就能转换为物理模型、生成脚本了。

文档评论(0)

0520 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档