erwin相关概念快速入门(albertyi原创)
1、如果只做文档,可以选择只建立logical view2、如果是做项目,需要同时使用logical view 和physical view3、一般logical view是用于做文档的,而physical view是用于生成或者导出脚本的4、表之间的三种连接线,第一种用于把表1中的主键插入到表2中的外键,且插入的作为表2的主键第二种用于多对多,很少用到第一种用于把表1中的主键插入到表2中的外键,且插入的不作为表2的主键
5、logical中的和physical中对应的表的名称可以不一样,一般在physical中的表的名称用英文名称在logical中的表的名称则无所谓,如果需要可以用中文
6、在physical view中的tools中的[forward engineer/schema generation]中在右侧的表中用对勾可以选择需要操作的项目
点击【preview】可以看到脚本,可以复制过来改改就能是脚本了点击【report】可以直接导出脚本点击【generate】则可以直接连接到数据库,把相关的scheme都建立起来
7、在logical view的一个entity上右键点击,选择attributes,就进入了给表加入column的界面了在general中选择一种基本类型(domain)比如string后,就能加入一个名称了,attribute name就是logical view中的名字column name就是用于生成脚本的名称。在general中的primary key的checkbox就是选为主键的地方了。在datatype中就能设定具体的数据类型,比如varchar2,number等。
8、关于索引和约束的建立右键在entity上,选择key group就能新建约束了
9、在attribute中选择datatype就能在validate中选择这个column相关的约束,在default中选择这个column的默认值了
10、关于domains的概念domain的概念在sql server中是支持的,可以在脚本的最开始就定义一堆的domain,然后在其后的脚本中都引用相关的域名,而不用直接原始的数据类型了。
for example:在一个项目的数据库设计中卡号用得非常的多:所以在erwin中logical view中选择domain,然后右键点击? <unkonwn>,new,就能创建一种新的domain在叫做cardseries。选择property可以给他选择相关的属性,比如选择datatype为varchar(18),还可以给它选择约束等等。
这个新建的domain 就能在这个项目中方便的使用了。
11、关于subject area的概念当整个项目设计表比较多的时候,很难在一个view中连接清楚所有的表的之间的关系这样就需要在subject area中分多个area,把相关的表放到相关的的area中去连接关系,这样比较方便设计。
1>右键点在一个相应的area上,然后go to ,就能看到那个area相应的view2>右键->property,就能设置当前area中需要哪些表,其中比较有用的一组按钮是最后一组(两个),能把选中的要加入area的表的相关的m级ancester和n级descendant同时加入area,至于m和n可以自己选择,非常方便。
注意:在任何非主area中新建的entity都会在<main subject area>中有一份,删除也是同时进行的
