11-3 MySQL 中对于 PowerDesigner 的使用
<h1 id="11-3-mysql-中对于-powerdesigner-的使用">11-3 MySQL 中对于 PowerDesigner 的使用</h1><p>@</p><div class="toc"><div class="toc-container-header">目录</div><ul><li>11-3 MySQL 中对于 PowerDesigner 的使用</li><li>1. PowerDesigner的使用<ul><li>1.1 开始界面</li><li>1.2 概念数据模型</li><li>1.3 物理数据模型</li><li>1.4 概念模型转为物理模型</li><li>1.5 物理模型转为概念模型</li><li>1.6 物理模型导出SQL语句</li></ul></li><li>2. 最后:</li></ul></div><p></p>
<hr>
<p><strong>这篇文章是我蹲在《尚硅谷》-康师傅博主家的 WiFi 上(不是),连夜 Ctrl+C / V 俩的镇站神文。</strong></p>
<p><strong>这篇转载只是为了,跟大家分享好内容,没有任何商业用途。如果你喜欢这篇文章,请一定要去原作者 B站《尚硅谷-MySQL从菜鸟到大牛》看看,说不定还能发现更多宝藏内容呢!</strong></p>
<h1 id="1-powerdesigner的使用">1. PowerDesigner的使用</h1>
<p>PowerDesigner是一款开发人员常用的数据库建模工具,用户利用该软件可以方便地制作 <code>数据流程图</code> 、 <code>概念数据模型</code> 、 <code>物理数据模型</code> ,它几乎包括了数据库模型设计的全过程,是Sybase公司为企业建模和设 计提供的一套完整的集成化企业级建模解决方案。</p>
<h2 id="11-开始界面">1.1 开始界面</h2>
<p>当前使用的PowerDesigner版本是16.5的。打开软件即是此页面,可选择Create Model,也可以选择Do Not Show page Again,自行在打开软件后创建也可以!完全看个人的喜好,在此我在后面的学习中不在显示此页面。</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605548-755121901.png"></p>
<p>“Create Model”的作用类似于普通的一个文件,该文件可以单独存放也可以归类存放。</p>
<p>“Create Project”的作用类似于文件夹,负责把有关联关系的文件集中归类存放。</p>
<h2 id="12-概念数据模型">1.2 概念数据模型</h2>
<p>常用的模型有4种,分别是 <code>概念模型(CDM Conceptual Data Model)</code> , <code>物理模型(PDM,Physical Data Model)</code> , <code>面向对象的模型(OOM Objcet Oriented Model)</code> 和 <code>业务模型(BPM Business Process Model)</code> ,我们先创建概念数据模型。</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605617-367895446.png"></p>
<p>点击上面的ok,即可出现下图左边的概念模型1,可以自定义概念模型的名字,在概念模型中使用最多的 就是如图所示的Entity(实体),Relationship(关系)</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605590-2052047599.png"></p>
<p><strong>Entity实体</strong></p>
<p>选中右边框中Entity这个功能,即可出现下面这个方框,需要注意的是书写name的时候,code自行补全,name可以是英文的也可以是中文的,但是code必须是英文的。</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093606738-1588005289.png"></p>
<p><strong>填充实体字段</strong></p>
<p>General中的name和code填好后,就可以点击Attributes(属性)来设置name(名字),code(在数据库中 的字段名),Data Type(数据类型) ,length(数据类型的长度)</p>
<ul>
<li>Name: 实体名字一般为中文,如论坛用户</li>
<li>Code: 实体代号,一般用英文,如XXXUser</li>
<li>Comment:注释,对此实体详细说明</li>
<li>Code属性:代号,一般用英文UID DataType</li>
<li>Domain域,表示属性取值范围如可以创建10个字符的地址域</li>
<li>M:Mandatory强制属性,表示该属性必填。不能为空</li>
<li>P:Primary Identifer是否是主标识符,表示实体唯一标识符</li>
<li>D:Displayed显示出来,默认全部勾选<br>
<img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605606-69600763.png"></li>
</ul>
<p>在此上图说明name和code的起名方法<br>
<img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605650-177108833.png"></p>
<p><strong>设置主标识符</strong></p>
<p>如果不希望系统自动生成标识符而是手动设置的话,那么切换到Identifiers选项卡,添加一行Identifier, 然后单击左上角的“属性”按钮,然后弹出的标识属性设置对话框中单击“添加行”按钮,选择该标识中使用的属性。例如将学号设置为学生实体的标识。<br>
<img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605508-922627939.png"></p>
<p><strong>放大模型</strong></p>
<p>创建好概念数据模型如图所示,但是创建好的字体很小,读者可以按着ctrl键同时滑动鼠标的可滑动按钮 即可放大缩写字体,同时也可以看到主标识符有一个*号的标志,同时也显示出来了,name,Data type和 length这些可见的属性</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093606124-1140869327.png"></p>
<p><strong>实体关系</strong></p>
<p>同理创建一个班级的实体(需要特别注意的是,点击完右边功能的按钮后需要点击鼠标指针状态的按钮 或者右击鼠标即可,不然很容易乱操作,这点注意一下就可以了),然后使用Relationship(关系)这个 按钮可以连接学生和班级之间的关系,发生一对多(班级对学生)或者多对一(学生对班级)的关系。</p>
<p>如图所示</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605456-513909579.png"></p>
<p>需要注意的是点击Relationship这个按钮,就把班级和学生联系起来了,就是一条线,然后双击这条线进 行编辑,在General这块起name和code</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605700-543183244.png"></p>
<p>上面的name和code起好后就可以在Cardinalities这块查看班级和学生的关系,可以看到班级的一端是一 条线,学生的一端是三条,代表班级对学生是一对多的关系即one对many的关系,点击应用,然后确定 即可</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093606046-1776680577.png"></p>
<p>一对多和多对一练习完还有多对多的练习,如下图操作所示,老师实体和上面介绍的一样,自己将 name,data type等等修改成自己需要的即可,满足项目开发需求即可。(comment是解释说明,自己可以写相关的介绍和说明)<br>
<img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605675-178851894.png"></p>
<p>多对多需要注意的是自己可以手动点击按钮将关系调整称为多对多的关系many对many的关系,然后点击应用和确定即可</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093606087-578626286.png"></p>
<p>综上即可完成最简单的学生,班级,教师这种概念数据模型的设计,需要考虑数据的类型和主标识码, 是否为空。关系是一对一还是一对多还是多对多的关系,自己需要先规划好再设计,然后就ok了。</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605607-1702442339.png"></p>
<h2 id="13-物理数据模型">1.3 物理数据模型</h2>
<p>上面是概念数据模型,下面介绍一下物理数据模型,以后 经常使用 的就是物理数据模型。打开 PowerDesigner,然后点击File-->New Model然后选择如下图所示的物理数据模型,物理数据模型的名字自己起,然后选择自己所使用的数据库即可。</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093606071-790132876.png"></p>
<p>创建好主页面如图所示,但是右边的按钮和概念模型略有差别,物理模型最常用的三个是 <code>table(表)</code> , <code>view(视图)</code>, <code>reference(关系) </code>;<br>
<img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605579-917568256.png"></p>
<p>鼠标先点击右边table这个按钮然后在新建的物理模型点一下,即可新建一个表,然后双击新建如下图所示,在General的name和code填上自己需要的,点击应用即可),如下图:</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605537-1738239671.png"></p>
<p>然后点击Columns,如下图设置,非常简单,需要注意的就是P(primary主键) , F (foreign key外键) , M(mandatory强制性的,代表不可为空) 这三个。</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605646-1515767790.png"></p>
<p>在此设置学号的自增(MYSQL里面的自增是这个AUTO_INCREMENT),班级编号同理,不多赘述!</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605972-1113973865.png"></p>
<p>在下面的这个点上对号即可,就设置好了自增</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605633-143176521.png"></p>
<p>全部完成后如下图所示。</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605925-152241432.png"></p>
<p>班级物理模型同理如下图所示创建即可</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605663-2112967521.png"></p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605639-817803954.png"></p>
<p>完成后如下图所示</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605716-491087348.png"></p>
<p>上面的设置好如上图所示,然后下面是关键的地方,点击右边按钮Reference这个按钮,因为是班级对学 生是一对多的,所以鼠标从学生拉到班级如下图所示,学生表将发生变化,学生表里面增加了一行,这 行是班级表的主键作为学生表的外键,将班级表和学生表联系起来。(仔细观察即可看到区别。)</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093607382-1502993377.png"></p>
<p>做完上面的操作,就可以双击中间的一条线,显示如下图,修改name和code即可</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605657-1422667929.png"></p>
<p>但是需要注意的是,修改完毕后显示的结果却如下图所示,并没有办法直接像概念模型那样,修改过后 显示在中间的那条线上面,自己明白即可。</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605609-1196167864.png"></p>
<p>学习了多对一或者一对多的关系,接下来学习多对对的关系,同理自己建好老师表,这里不在叙述,记得老师编号自增,建好如下图所示</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605611-984278281.png"></p>
<p>下面是多对多关系的关键,由于物理模型多对多的关系需要一个中间表来连接,如下图,只设置一个字 段,主键,自增</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605563-1409334847.png"></p>
<p>点击应用,然后设置Columns,只添加一个字段</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605611-1202071870.png"></p>
<p>这是设置字段递增,前面已经叙述过好几次</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605504-755285141.png"></p>
<p>设置好后如下图所示,需要注意的是有箭头的一方是一,无箭头的一方是多,即一对多的多对一的关系 需要搞清楚,学生也可以有很多老师,老师也可以有很多学生,所以学生和老师都可以是主体;</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093606540-158239471.png"></p>
<p>可以看到添加关系以后学生和教师的关系表前后发生的变化</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605683-37834383.png"></p>
<h2 id="14-概念模型转为物理模型">1.4 概念模型转为物理模型</h2>
<p>1:如下图所示先打开概念模型图,然后点击Tool,如下图所示</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605630-824610888.png"></p>
<p>点开的页面如下所示,name和code已经从概念模型1改成物理模型1了</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605635-1590705828.png"></p>
<p>完成后如下图所示,将自行打开修改的物理模型,需要注意的是这些表的数据类型已经自行改变了,而 且中间表出现两个主键,即双主键</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605509-1093088159.png"></p>
<h2 id="15-物理模型转为概念模型">1.5 物理模型转为概念模型</h2>
<p>上面介绍了概念模型转物理模型,下面介绍一下物理模型转概念模型(如下图点击操作即可)</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093607629-1870880669.png"></p>
<p>然后出现如下图所示界面,然后将物理修改为概念 ,点击应用确认即可</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605606-1248114602.png"></p>
<p>点击确认后将自行打开如下图所示的页面,自己观察有何变化,如果转换为oracle的,数据类型会发生变 化,比如Varchar2等等);</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605942-1115628277.png"></p>
<h2 id="16-物理模型导出sql语句">1.6 物理模型导出SQL语句</h2>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093607439-1837772149.png"></p>
<p>打开之后如图所示,修改好存在sql语句的位置和生成文件的名称即可</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093606498-1663637690.png"></p>
<p>在Selection中选择需要导出的表,然后点击应用和确认即可</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605587-1667478771.png"></p>
<p>完成以后出现如下图所示,可以点击Edit或者close按钮</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093605818-303369779.png"></p>
<p>自此,就完成了导出sql语句,就可以到自己指定的位置查看导出的sql语句了;PowerDesigner在以后在 项目开发过程中用来做需求分析和数据库的设计非常的方便和快捷。</p>
<h1 id="2-最后">2. 最后:</h1>
<blockquote>
<p>“在这个最后的篇章中,我要表达我对每一位读者的感激之情。你们的关注和回复是我创作的动力源泉,我从你们身上吸取了无尽的灵感与勇气。我会将你们的鼓励留在心底,继续在其他的领域奋斗。感谢你们,我们总会在某个时刻再次相遇。”</p>
<p><img src="https://img2024.cnblogs.com/blog/3084824/202507/3084824-20250703093606897-928782744.gif"></p>
</blockquote><br><br>
来源:https://www.cnblogs.com/TheMagicalRainbowSea/p/18962983
頁:
[1]