PowerDesigner生成MS SQL foreign 的问题
简单地说,就是从CDM生成PDM的时候,releationship约束无效,不能生成外键约束的代码。生成基于oracle的pdm没问题,ms sql server有问题
这里的是sql server 2005
Power Designer是15.0.0.2613
看起來是PD的bug,解決辦法是在PDM畫面中點選Model->References...
會跳出一個視窗裡頭有這個PDM的所有Reference的相關資訊,最後有個欄位叫Implementation可以直接設定成Declarative就好了。
補充一下,如果Implementaion無法強制設成Declarative,可將Current DBMS設成Sql Server 2000即可。設定完後再改回來Sql server 2005/2008即可。 不知道甚麼原因導致Sql 2005/2008的DBMS會強制Reference Integrity設成用trigger的方式。
当从CDM转到PDM(MS SQL Server)的时候,在CDM中的ReleationShip不能在CDM的foreign生成有效代码,References的Privew标签显示内容为:
-- The preview is empty because of the setting.
-- Check the generation option.
查看integrity标签,implementation显示为trigger,update/delete constraint分别为restrict,改变为update/delete constraint为none,并且改implementation为declarative后,preview中代码显示正常,如下:
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('meb_FriendRequest') and o.name = 'FK_MEB_FRIE_RS_MEMBER_MEB_MEMB')
alter table meb_FriendRequest
drop constraint FK_MEB_FRIE_RS_MEMBER_MEB_MEMB
go
alter table meb_FriendRequest
add constraint FK_MEB_FRIE_RS_MEMBER_MEB_MEMB foreign key (Member_ID)
references meb_Member (Member_ID)
go
根据提示,在创建pdm的时候查看选项,发现for sql server与for oracle内容不一样。 实验步骤:
1.建立一个cdm
2.建立两个实体,分别是parent和child,并且在这两个实体中间建立一对多的relationship。
3.将cdm生成for oracle 10g的pdm,查看child表的外键约束,在标签preview中可以看到创建外键约束的代码
4.将cdm生成for ms sql 2005的pdm,
相关文档:
系统环境:Windows 7
软件环境:Visual C++ 2008 SP1 +SQL Server 2005
本次目的:编写一个航空管理系统
这是数据库课程设计的成果,虽然成绩不佳,但是作为我用VC++ 以来编写的最大程序还是传到网上,以供参考。用VC++ 做数据库设计并不容易,但也不是不可能。以下是我的程序界面,后面 ......
CEILING:
将参数 Number 向上舍入(沿绝对值增大的方向)为最接近的 significance 的倍数。例如,如果您不愿意使用像“分”这样的零钱,而所要购买的商品价格为 $4.42,可以用公式 =CEILING(4.42,0.1) 将价格向上舍入为以“角”表示。
语法
CEILING(number,significance)
Number 要四舍五入的数值 ......
为包含列的对象(如视图或表)的每列返回一行。下面是包含列的对象类型的列表。
表值程序集函数 (FT)
内联表值 SQL 函数 (IF)
内部表 (IT)
系统表 (S)
表值 SQL 函数 (TF)
用户表 (U)
视图 (V)
列名 数据类型 说明
object_id
int
此列所属对象的 ID。
name
sysname
列名。在对象中是唯一的。
column_id
in ......
http://www.oreilly.com/catalog/artofsql (原书)
http://www.oreilly.com.cn/book.php?bn=978-7-121-05834-9 (中文版)
数据库技术是企业信息化开发的基础。在制造业信息化领域从业多年,自己对这块知识却一直零碎杂乱,应该理顺思路,为架构设计的目标建立基础。
此书 ......
这是一条颠覆常规的插入方法,一条INSERT语句可以完成向多张表的插入任务。小小地展示一下这种插入方法。
1.创建表T并初始化测试数据,此表作为数据源。
sec@ora10g> create table t (x number(10), y varchar2(10));
sec@ora10g> insert into t values (1,'a');
sec@ora10g> insert into t values (2,'b');
......