最近用PowerDesigner15做数据库设计的时候发现如果先做好了CDM图,然后生成PDM,再生成SQL 2005或SQL 2008脚本,发现始终无法生成外键约束。
我估计很多人都遇到了类似的问题。 经过查找和摸索终于解决了这个问题,现在将过程叙述如下,希望对大家有帮助。
实验过程如下:
1、生成在CDM中建立两个实体Entity_1和Entity_2,并建立关系Relationship。
2、自动生成MS SQL Server 2008的PDM。
3、选择DBMS类型为SQL 2008然后生成Database脚本
/*==============================================================*/
/* DBMS name: Microsoft SQL Server 2008 */
/* Created on: 2010/4/5 19:36:09 */
/*==============================================================*/
if exists (select 1
from sysobjects
where id = object_id('Entity_1')
and type = 'U')
drop table Entity_1
go
if exists (select 1
from sysindexes
where id = object_id('Entity_2')
and name = 'Relationship_1_FK'
and indid > 0
and indid < 255)
drop index Entity_2.Relationship_1_FK
go
if exists (select 1
from sysobjects
where id = object_id('Entity_2')
and type = 'U')
drop table Entity_2
go
/*==============================================================*/
/* Table: Entity_1 */
/*==============================================================*/
create table Entity_1 (
Attribute_1 int not null,
Attribute_2 int null,
constraint PK_ENTITY_1 primary key nonclustered (Attribute_1)
)
go
/*==============================================================*/
/* Table: Entity_2 */
/*==============================================================*/
create table Entity_2 (
Attribute_3 int not null,
Attribute_1 int null,
Attribute_4 int null,
constraint PK_ENTITY_2 primary key nonclustered (Attribute_3)
)
go
/*==============================================================*/
/* Index: Relationship_1_FK */
/*==============================================================*/
create index Relationship_1_FK on Entity_2 (
Attribute_1 ASC
)
go
从上面脚本可以看出没有生成需要的外键约束,只是生成了相关索引。
解决方法如下:
- 打开生成的PDM
- 将DBMS类型换为MS SQL 2000
- 在Model菜单中选择References命令,可以看到最后的Implementation被设置为Trigger
- 将Implementation被设置为Declarative(如果没有第二步就不能完成本步)
- 将DBMS类型换为MS SQL 2008
-
生成MS SQL 2008数据库生成脚本,能够正常生成需要的外键
/*==============================================================*/
/* DBMS name: Microsoft SQL Server 2008 */
/* Created on: 2010/4/5 19:49:25 */
/*==============================================================*/
if exists (select 1
from sys.sysreferences r join sys.sysobjects o on (o.id = r.constid and o.type = 'F')
where r.fkeyid = object_id('Entity_2') and o.name = 'FK_ENTITY_2_RELATIONS_ENTITY_1')
alter table Entity_2
drop constraint FK_ENTITY_2_RELATIONS_ENTITY_1
go
if exists (select 1
from sysobjects
where id = object_id('Entity_1')
and type = 'U')
drop table Entity_1
go
if exists (select 1
from sysindexes
where id = object_id('Entity_2')
and name = 'Relationship_1_FK'
and indid > 0
and indid < 255)
drop index Entity_2.Relationship_1_FK
go
if exists (select 1
from sysobjects
where id = object_id('Entity_2')
and type = 'U')
drop table Entity_2
go
/*==============================================================*/
/* Table: Entity_1 */
/*==============================================================*/
create table Entity_1 (
Attribute_1 int not null,
Attribute_2 int null,
constraint PK_ENTITY_1 primary key nonclustered (Attribute_1)
)
go
/*==============================================================*/
/* Table: Entity_2 */
/*==============================================================*/
create table Entity_2 (
Attribute_3 int not null,
Attribute_1 int null,
Attribute_4 int null,
constraint PK_ENTITY_2 primary key nonclustered (Attribute_3)
)
go
/*==============================================================*/
/* Index: Relationship_1_FK */
/*==============================================================*/
create index Relationship_1_FK on Entity_2 (
Attribute_1 ASC
)
go
alter table Entity_2
add constraint FK_ENTITY_2_RELATIONS_ENTITY_1 foreign key (Attribute_1)
references Entity_1 (Attribute_1)
go
(完)
分享到:
相关推荐
然而,逆向工程的缺点在于,生成的模型可能缺乏中文注释,外键关系也可能不完整,特别是当数据库中未明确定义外键约束时。因此,生成的模型可能需要手动调整和完善。 另一种方法是通过SQL脚本逆向工程生成PDM,这...
3. 转换为PDM:在CDM完成后,选择目标数据库系统(如MS SQL Server),PowerDesigner会自动生成符合该数据库系统的PDM。这个过程中,PowerDesigner会处理数据类型的映射、约束的转换、索引的创建等。 4. 调整优化...
轴类零件加工工艺设计.zip
资源内项目源码是来自个人的毕业设计,代码都测试ok,包含源码、数据集、可视化页面和部署说明,可产生核心指标曲线图、混淆矩阵、F1分数曲线、精确率-召回率曲线、验证集预测结果、标签分布图。都是运行成功后才上传资源,毕设答辩评审绝对信服的保底85分以上,放心下载使用,拿来就能用。包含源码、数据集、可视化页面和部署说明一站式服务,拿来就能用的绝对好资源!!! 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、大作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.txt文件,仅供学习参考, 切勿用于商业用途。
seaborn基本绘图人力资源数据集
移动机器人(sw三维)
自制html网页源代码查看器
3吨叉车的液压系统设计().zip
1_实验三 扰码、卷积编码及交织.ppt
北京交通大学软件学院自命题科目考试大纲.pdf
雅鲁藏布江流域 shp矢量数据 (范围+DEM).zip
基于RUST的数据结构代码示例,栈、队列、图等
NIFD:2024Q1房地产金融报告
详细介绍及样例数据:https://blog.csdn.net/li514006030/article/details/146916652
内容概要:本文档详细介绍了Java虚拟机(JVM)的相关知识点,涵盖Java内存模型、垃圾回收机制及算法、垃圾收集器、内存分配策略、虚拟机类加载机制和JVM调优等内容。首先阐述了Java代码的编译和运行过程,以及JVM的基本组成部分及其运行流程。接着深入探讨了JVM的各个运行时数据区,如程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区等的作用和特点。随后,文档详细解析了垃圾回收机制,包括GC的概念、工作原理、优点和缺点,并介绍了几种常见的垃圾回收算法。此外,文档还讲解了JVM的分代收集策略,新生代和老年代的区别,以及不同垃圾收集器的工作方式。最后,文档介绍了类加载机制、JVM调优的方法和工具,以及常用的JVM调优参数。 适合人群:具备一定Java编程基础的研发人员,尤其是希望深入了解JVM内部机制、优化程序性能的技术人员。 使用场景及目标:①帮助开发人员理解Java代码的编译和执行过程;②掌握JVM内存管理机制,包括内存分配、垃圾回收等;③熟悉类加载机制,了解类加载器的工作原理;④学会使用JVM调优工具,掌握常用调优参数,提升应用程序性能。 其他说明:本文档内容详尽,适合用作面试准备材料和技术学习资料,有助于提高开发人员对JVM的理解和应用能力。
Android项目原生java语言课程设计,包含LW+ppt
戴德梁行&中国房地产协会:2021亚洲房地产投资信托基金研究报告
Android项目原生java语言课程设计,包含LW+ppt
Thinkphp6.0+vue个人虚拟物品发卡网站源码 支持码支付对接 扫码自动发货 源码一共包含两个部分thinkphp6.0后端文件,以及vue前端文件.zip