《MySQL高级篇》数据库建模工具---PowderDesigner的使用教程
文章目录
- PowerDesigner的使用
- 11.1 开始界面
- 11.2 概念数据模型
- 11.3 物理数据模型
- 11.4 概念模型转为物理模型
- 11.5 物理模型转为概念模型
- 11.6 物理模型导出SQL语句
PowerDesigner的使用
PowerDesigner是一款开发人员常用的数据库建模工具,用户利用该软件可以方便地制作 数据流程图 、概念数据模型 、 物理数据模型
,它几乎包括了数据库模型设计的全过程,是Sybase公司为企业建模和设计提供的一套完整的集成化企业级建模解决方案
安装: https://www.cnblogs.com/luyj00436/p/16932603.html
11.1 开始界面
当前使用的PowerDesigner版本是16.5的。打开软件即是此页面,可选择Create Model,也可以选择Do Not Show page Again,自行在打开软件后创建也可以!完全看个人的喜好,在后面的学习中不在显示此页面。
接下来我们开始为数据库建模
Create Model
的作用类似于普通的一个文件,该文件可以单独存放也可以归类存放。Create Project
的作用类似于文件夹,负责把有关联关系的文件集中归类存放。
11.2 概念数据模型
常用的模型有4种,分别是 概念模型
(CDM Conceptual Data Model) , 物理模型
(PDM,Physical Data Model) , 面向对象的模型
(OOM Objcet Oriented Model) 和 业务模型
(BPM Business Process Model) 。
1、我们先创建概念数据模型
点击上面的ok,即可出现下图左边的概念模型1,可以自定义概念模型的名字,在概念模型中使用最多的就是如图所示的Entity(实体),Relationship(关系)
2、选中右边框中Entity这个功能,创建一个实体。双击实体,即可出现下面这个方框。需要注意的是书写name的时候,code自行补全,name可以是英文的也可以是中文的,但是code必须是英文的。
3、填充实体字段
General中的name和code填好后,就可以点击Attributes(属性)来设置name(名字),code(在数据库中的字段名),Data Type(数据类型) ,length(数据类型的长度)
Name: 实体名字一般为中文,如论坛用户
Code: 实体代号,一般用英文,如XXXUser
Comment:注释,对此实体详细说明
Code属性:代号,一般用英文UID DataType
Domain域,表示属性取值范围如可以创建10个字符的地址域
M:Mandatory强制属性,表示该属性必填。不能为空
P:Primary Identifer是否是主标识符,表示实体唯一标识符
D:Displayed显示出来,默认全部勾选
Data Type可以使用点击下拉框或…的方式设置,字符串类型必须设置长度
Ctrl+D删除行或者点击 ×
4、设置主标识符
如果不希望系统自动生成标识符而是手动设置的话,那么切换到Identifiers选项卡,添加一行Identifier,然后单击左上角的“属性”按钮,然后弹出的标识属性设置对话框中单击“添加行”按钮,选择该标识中使用的属性。例如将学号设置为学生实体的标识。
5、放大模型
创建好概念数据模型如图所示,但是创建好的字体很小,读者可以按着ctrl键
同时滑动鼠标的可滑动按钮即可放大缩写字体,同时也可以看到主标识符有一个*号的标志,同时也显示出来了,name,Data type和length这些可见的属性
6、实体关系
同理创建一个班级的实体(需要特别注意的是,点击完右边功能的按钮后需要点击鼠标指针状态的按钮或者右击鼠标即可,不然很容易乱操作,这点注意一下就可以了),然后使用Relationship
(关系)这个按钮可以连接学生和班级之间的关系,建立一对多(班级对学生)或者多对一(学生对班级)的关系。
需要注意的是点击Relationship这个按钮,就把班级和学生联系起来了,就是一条线,然后双击这条线进行编辑,在General这块起name和code
面的name和code起好后就可以在Cardinalities这块查看班级和学生的关系,可以看到班级的一端是一条线,学生的一端是三条,代表班级对学生是一对多的关系即one对many的关系,点击应用,然后确定即可
一对多和多对一练习完还有多对多的练习,如下图操作所示,老师实体和上面介绍的一样,自己将name,data type等等修改成自己需要的即可,满足项目开发需求即可。(comment是解释说明,自己可以写相关的介绍和说明)
多对多需要注意的是自己可以手动点击按钮将关系调整称为多对多的关系many对many的关系,然后点击应用和确定即可
综上即可完成最简单的学生,班级,教师这种概念数据模型的设计,需要考虑数据的类型和主标识码,是否为空。关系是一对一还是一对多还是多对多的关系,自己需要先规划好再设计,然后就ok了。
最后CTRL+S
保存为 学生管理系统-1.cdm
11.3 物理数据模型
上面是概念数据模型,下面介绍一下物理数据模型,以后 经常使用 的就是物理数据模型。打开PowerDesigner,然后点击File–>New Model然后选择如下图所示的物理数据模型,物理数据模型的名字自己起,然后选择自己所使用的数据库即可。
创建好主页面如图所示,但是右边的按钮和概念模型略有差别,物理模型最常用的三个是
table(表)
, view(视图)
, reference(关系)
;
鼠标先点击右边table这个按钮然后在新建的物理模型点一下,即可新建一个表,然后双击新建如下图所示,在General的name和code填上自己需要的,点击应用即可),如下图:
然后点击Columns,如下图设置,非常简单,需要注意的就是P(primary主键) , F (foreign key外键) ,M(mandatory强制性的,代表不可为空) 这三个
在此设置学号的自增(MYSQL里面的自增是这个AUTO_INCREMENT),班级编号同理,不多赘述!
在下面的这个点上对号即可,就设置好了自增
全部完成后如下图所示。
班级物理模型同理如下图所示创建即可
完成后如下图所示
上面的设置好如上图所示,然后下面是关键的地方,点击右边按钮Reference这个按钮,因为是班级对学生是一对多的,所以鼠标从学生拉到班级如下图所示,学生表将发生变化,学生表里面增加了一行,这行是班级表的主键作为学生表的外键,将班级表和学生表联系起来。(仔细观察即可看到区别。)
做完上面的操作,就可以双击中间的一条线,显示如下图,修改name和code即可
注意:可以在Integrity中为显示的关系起名字。默认是FK+Code
,比如:FK_student_class_r
学习了多对一或者一对多的关系,接下来学习多对对的关系,同理自己建好老师表,这里不在叙述,记得老师编号自增,建好如下图所示
下面是多对多关系的关键,由于物理模型多对多的关系需要一个中间表来连接,如下图,只设置一个字段,主键,自增
点击应用,然后设置Columns,只添加一个字段
这是设置字段递增,前面已经叙述过好几次
设置好后如下图所示:
需要搞清楚,学生也可以有很多老师,老师也可以有很多学生,所以学生和老师都可以是主体;然后我们开始添加学生和教师的关系*~*
思考一个问题:为什么N:N,需要建立中间表呢,有什么好处呢?
11.4 概念模型转为物理模型
如下图所示先打开概念模型图,然后点击Tool,如下图所示
点开的页面如下所示,name和code已经从概念模型1改成物理模型1了
完成后如下图所示,将自行打开修改的物理模型,需要注意的是这些表的数据类型已经自行改变了,而且中间表出现两个主键,即双主键
11.5 物理模型转为概念模型
上面介绍了概念模型转物理模型,下面介绍一下物理模型转概念模型(如下图点击操作即可)
然后出现如下图所示界面,然后将物理修改为概念 ,点击应用确认即可
点击确认后将自行打开如下图所示的页面,自己观察有何变化,如果转换为oracle的,数据类型会发生变化,比如Varchar2等等);
11.6 物理模型导出SQL语句
下面介绍一下物理模型导出SQL语句(点击Database按钮的Generate Database或者按ctrl+G)
打开之后如图所示,修改好存在sql语句的位置和生成文件的名称即可
在Selection中选择需要导出的表,然后点击应用和确认即可
完成以后出现如下图所示,可以点击Edit或者close按钮
查看保存的sql文件:
至此,就完成了导出sql语句,就可以到自己指定的位置查看导出的sql语句了;PowerDesigner在以后在项目开发过程中用来做需求分析和数据库的设计非常的方便和快捷~
关于PowerDesigner导出SQL,字段没有注释,解决办法:https://blog.csdn.net/weixin_42732880/article/details/125869158
《MySQL高级篇》数据库建模工具---PowderDesigner的使用教程相关推荐
- MySQL高级篇知识点——数据库的设计规范
目录 1.为什么需要数据库设计? 2.范式 2.1.范式简介 2.2.范式都包括哪些 2.3.键和相关属性的概念 2.4.第一范式 (1NF) 2.5.第二范式 (2NF) 2.6.第三范式 (3NF ...
- MySQL高级篇知识点——其它数据库日志
目录 1.其他数据库日志 1.1.日志类型 1.2.日志的弊端 2.慢查询日志 (slow query log) 3.通用查询日志 (general query log) 3.1.问题场景 3.2.查 ...
- MySQL高级篇_第11章_数据库的设计规范
1. 为什么需要数据库设计 我们在设计数据表的时候,要考虑很多问题. 比如 用户都需要什么数据?需要在数据表中保存哪些数据 如何保证数据表中数据的 正确性,当插入.删除.更新的时候该进行怎样的 约束检 ...
- 好用的mysql数据库建模工具有哪些
有很多好用的MySQL数据库建模工具,以下是一些常用的工具: MySQL Workbench:MySQL官方推出的免费数据库建模工具,支持创建.修改和维护MySQL数据库,同时还提供了可视化的建模和管 ...
- mysql高级篇学习笔记
目录 前言 1 mysql安装及运行(linux环境) 1.1 安装前检查 1.2 MySQL卸载 ①**关闭 mysql 服务** ②**查看当前 mysql 安装状况** ③**卸载上述命令查询出 ...
- MySQL高级篇知识点——索引优化与查询优化
目录 1.数据准备 1.1.建库建表 1.2.创建相关函数 1.3.创建存储过程 1.4.调用存储过程 1.5.删除某表上的索引 2.索引失效案例 2.1.全值匹配 2.2.最佳左前缀匹配原则 2.3 ...
- PDMan-2.1.3 发布:用心开源,免费的国产数据库建模工具
2019独角兽企业重金招聘Python工程师标准>>> 一.软件介绍 PDMan 是一款开源免费的数据库模型建模工具,是PowerDesigner之外另一种更好的选择.支持Windo ...
- 国产数据库建模工具,看到界面第一眼,良心了!
软件开发中,数据建模是必不可少的,说到数据库建模工具,很多人想到的第一个工具就是powerdesigner,但是单数据库建模这块来说,给人的感觉还是太重了,并且不支持多种客户端,像我现在用Mac只能望 ...
- MySQL高级篇(事务视图存储过程与函数)
目录 一.事务 1.1什么是事务? 1.2事务的特性 1.3事务的分类 1.4事务的操作步骤 1.5事务的隔离级别(面试题常考) 二.视图 2.1视图的操作 2.1.1视图的创建 2.1.2视图更新( ...
最新文章
- 可视化工具gephi源码探秘(二)---导入netbeans
- NIFI从mysql导入Hbase
- 软件开发文档整理(之)一张示意图 | 清晰明了
- win10系统电脑wifi图标不见了的开启方法
- python表达式3 5_python3 第五章 - 什么是变量、运算符、表达式
- ubuntu下搭建车场环境(代码使用jekins构建)
- 【渝粤教育】国家开放大学2018年秋季 1301T病理生理学 参考试题
- 利用Nginx+Mono+Fastcgi代替IIS对Asp.Net进行反向代理
- 2008服务器系统只有回收站,清除Windows Server 2008 R2中所有用户的回收站
- OpenDrive格式的高精度地图
- 数字图像处理 笔记--2
- 【项目实战】Airbnb爱彼迎-数据分析与建模
- 视频、图像原理 设配选择 图像出入门概念理解
- 使用tesserocr二值化识别知网登录验证码
- leetcode:BFS/DFS--腐烂的橘子
- 计算机键盘在线识别,电脑键盘识别(3) -电脑资料
- HTTP的常用方法、GET和POST的区别
- C陷阱与缺陷 第3章 语义“陷阱” 3.4 避免“举偶法”
- 如何用关键字优化网站?
- 浅析Nature Communications和Scientific Reports