当前位置:七道奇文章资讯数据防范Oracle防范
日期:2011-01-25 22:55:00  来源:本站整理

<b>Oracle定义约束 外键约束-入门底子</b>[Oracle防范]

赞助商链接



  本文“<b>Oracle定义约束 外键约束-入门底子</b>[Oracle防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
    外键约束保证参照完好性.外键约束限定了一个列的取值范围.一个例子就是限定州名缩写在一个有限值调集合,这个值调集是别的一个掌握构造——一张父表

    下面我们成立一张参照表,它供应了完好的州缩写列表,然后利用参照完好性确保学生们有精确的州缩写.第一张表是州参照表,State作为主键

CREATE TABLE state_lookup
(state      VARCHAR2(2),
  state_desc VARCHAR2(30)) TABLESPACE student_data; ALTER TABLE state_lookup
  ADD CONSTRAINT pk_state_lookup PRIMARY KEY (state)
  USING INDEX TABLESPACE student_index;

    然后插入几行记录:

INSERT INTO state_lookup VALUES ('CA', 'California');
INSERT INTO state_lookup VALUES ('NY', 'New York');
INSERT INTO state_lookup VALUES ('NC', 'North Carolina');

    我们通过实现父子关系来保证参照完好性,图示以下

 ---------------   外键字段存在于Students表中
|State_lookup  |  是State字段
---------------   一个外键必须参照主键或Unique字段
 |           这个例子中,我们参照的是State字段
 |           它是一个主键字段(参看DDL)
           /|\
 ---------------
|  Students    |
 ---------------

    上图显示了State_Lookup表和Students表间一对多的关系,State_Lookup表定义了州缩写通用调集——在表中每一个州呈现一次.因此,State_Lookup表的主键是State字段.

    State_Lookup表中的一个州名可以在Students表中呈现多次.有很多学生来自同一个州,一次,在表State_Lookup和Students之间参照完好性实现了一对多的关系.

    外键同时保证Students表中State字段的完好性.每一个学生老是有个State_lookup表中成员的州缩写.

    外键约束成立在子表.下面在students表上成立一个外键约束.State字段参照state_lookup表的主键.

    1、成立表

CREATE TABLE students
(student_id    VARCHAR2(10) NOT NULL,
student_name  VARCHAR2(30) NOT NULL,
college_major VARCHAR2(15) NOT NULL,
status        VARCHAR2(20) NOT NULL,
state         VARCHAR2(2),
license_no    VARCHAR2(30)) TABLESPACE student_data;

    2、成立主键

ALTER TABLE students
ADD CONSTRAINT pk_students PRIMARY KEY (student_id)
USING INDEX TABLESPACE student_index;

    3、成立Unique约束

ALTER TABLE students
ADD CONSTRAINT uk_students_license
UNIQUE (state, license_no)
USING INDEX TABLESPACE student_index;

    4、成立Check约束

ALTER TABLE students
ADD CONSTRAINT ck_students_st_lic
CHECK ((state IS NULL AND license_no IS NULL) OR
(state IS NOT NULL AND license_no is NOT NULL));

    5、成立外键约束

ALTER TABLE students
ADD CONSTRAINT fk_students_state
FOREIGN KEY (state) REFERENCES state_lookup (state);


  以上是“<b>Oracle定义约束 外键约束-入门底子</b>[Oracle防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .