zoukankan      html  css  js  c++  java
  • 讲解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)。把主表中主键修正为一个新的值时,呼应修正子表中外键的值;或许删除主表中主键的纪录时,要呼应删除子表中外键的纪录




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

  • 相关阅读:
    Maven学习笔记
    [学习笔记] 网络流
    [Contest on 2021.11.3] 女子口阿
    [杂题合集] 25 岁小伙突然没了心跳,他的习惯很多年轻人都有!
    CSP 2021 提高组游记
    [题目小结] 可持久化数据结构
    [学习笔记] 无向图和有向图的连通分量
    [Contest on 2021.10.17] HustOJ 就是个 **
    [Contest on 2021.10.15] 细思极恐
    妖怪寺外,灯火通明
  • 原文地址:https://www.cnblogs.com/zgqjymx/p/1974037.html
Copyright © 2011-2022 走看看