讲解SQL与Oracle外键束厄狭窄中的级联删除



   源头:赛迪网    作者:Byron

这篇文章次要介绍了SQL与Oracle外键束厄狭窄中的级联删除,更多内容请参考下文:

最近软件零碎中要删除一笔纪录,就要关联到同时删除良多几多张表,它们之间还存在着束厄狭窄关系.以是思索到在设立创设表时加上束厄狭窄关系,注重内容如下:

SQL的外键束厄狭窄可以完成级联删除与级联更新;

ORACLE则只充许级联删除。

SQL级联删除与级联更新行使格式:

CREATE TABLE A001(ID INT PRIMARY KEY,NAME VARCHAR(20))

CREATE TABLE A002(ID INT REFERENCES A001(ID)ON DELETE CASCADE ON UPDATE CASCADE,AGE TINYINT)

ORACLE级联删除行使格式:

CREATE TABLE A001(ID INT PRIMAY KEY,NAME VARCHAR2(20))

CREATE TABLE A002(ID INT REFERENCES A001(ID)ON DELETE CASCADE,AGE NUMBER(2,0))

--------------

CREATE TABLE groups

(

id VARCHAR2(16) CONSTRAINT pk_groupid PRIMARY KEY,

name VARCHAR2(32),

description VARCHAR2(50)

)

TABLESPACE userspace;

CREATE TABLE usringrp

(

group_id VARCHAR2(16) CONSTRAINT fk_uing_grpid

REFERENCES groups(id)

ON DELETE CASCADE,

user_id VARCHAR2(16)

)

TABLESPACE userspace;

---------------

PowerDesigner

参照通通性束厄狭窄

限制(Restrict)。不理睬停止修正或删除操作。若修正或删除主表的主键时,假设子表中存在子纪录,零碎将孕育发作一个错误提醒。这是缺省的参照通通性设置。

置空(Set Null)。假设外键列答应为空,若修正或删除主表的主键时,把子表中参照的外键列设置为空值(NULL)。

置为缺省(Set Default)。假设指定了缺省值,若修正或删除主表的主键时,把子表中参照的外键设置为缺省值(Default)。

级联(Cascade)。把主表中主键修正为一个新的值时,呼应修正子表中外键的值;或许删除主表中主键的纪录时,要呼应删除子表中外键的纪录




版权声明: 原创作品,答应转载,转载时请务必以超链接形式标明文章 原始来由 、作者信息和本声明。否则将追究功令责任。

posted @ 2011-03-07 13:44  蓝色的天空III  阅读(190)  评论(0编辑  收藏  举报