【数据库系统概念】实验四 完整性

1、实验目的

  1. 熟悉通过SQL对数据进行完整性控制。

  2. 完成书本上习题的上机练习。

2、实验平台KingbaseES

KingbaseES及其交互式查询工具ISQLW。

3、实验内容和要求

因为完整性约束大部分是在定义表结构时进行的,因此可能多次定义表,如果表名重复,先将旧表删除再建立新表

3.1 实体完整性

实体完整性要求每个数据表都必须有主键,而作为主键的所有字段,其属性必须是独一及非空值。

关系模型的实体完整性在CREATE TABLE中用PRIMARY KEY定义。定义主码的方法分为定义为列级约束条件和定义为表级约束条件。

定义表Student,将其中的Sno属性定义为主码:

CREATE TABLE Student(
    Sno CHAR(7) PRIMARY KEY,
    Sname CHAR(8) NOT NULL,
    Ssex CHAR(2),
    Sage SMALLINT,
    Sdept CHAR(20));

也可以:

CREATE TABLE Student(
    Sno CHAR(7) ,
    Sname CHAR(8) NOT NULL,
    Ssex CHAR(2),
    Sage SMALLINT,
    Sdept CHAR(20),
    PRIMARY KEY(Sno));

对于由多个属性构成的码,只能够将其定义为表级约束条件,而无法用列级约束条件来实现。

定义表SC,将其中的Sno,Cno属性定义为主码

CREATE TABLE SC(
    Sno CHAR(7) NOT NULL,
    Cno CHAR(4) NOT NULL,
    Grade SMALLINT,
    PRIMARY KEY(Sno,Cno));

3.2 参照完整性

参照的关系中的属性值必须能够在被参照关系找到或者取空值,否则不符合数据库的语义。

关系模式的参照完整性是在CREATE TABLE中用FOREIGN KEY语句来定义的,并用REFERENCES来指明外码参照的是哪些表的主码。

定义表SC,其中Sno参照表Student的主码Sno,Cno参照表Course的主码Cno。

CREATE TABLE SC(
    Sno CHAR(7) NOT NULL,
    Cno CHAR(4) NOT NULL,
    Grade SMALLINT,
    PRIMARY KEY(Sno,Cno),
    FOREIGN KEY(Sno) REFERENCES Student(Sno),
    FOREIGN KEY(Cno) REFERENCES Course(Cno));

3.3 用户自定义完整性

用户自定义完整性指针对某一具体关系数据库的约束条件,它反映某一具体应用所涉及的数据必须满足的语义要求。

列值非空:

在定义SC表时,Sno、Cno和Grade属性都不允许取空值。在不特别声明的情况下,非码属性的值是允许取空值的。

CREATE TABLE SC(
    Sno CHAR(7) NOT NULL,
    Cno CHAR(4) NOT NULL,
    Grade SMALLINT NOT NULL);

列值唯一:

建立部门表Dept,要求部门名称Dname取值唯一,部门编号属性Deptno为主码。

CREATE TABLE Dept(
    Deptno NUMERIC(7) PRIMARY KEY,
    Dname VARCHAR(9) UNIQUE,
    Loc VARCHAR(10));

CHECK短语:

CHECK短语指定列值应该满足的条件。

定义表Student,属性Ssex的值只允许取“男”或者“女”。

CREATE TABLE Student(
    Sno CHAR(7) PRIMARY KEY,
    Sname CHAR(8) NOT NULL,
    Ssex CHAR(2) CHECK(Ssex IN('男','女')),  /*CHECK语句约束条件*/
    Sage SMALLINT,
    Sdept CHAR(20));

定义表SC,属性Grade的值定义在[0,100]之间。

CREATE TABLE SC(
    Sno CHAR(7) NOT NULL,
    Cno CHAR(4) NOT NULL,
    Grade SMALLINT CHECK (Grade>=0 AND Grade<=100),
    PRIMARY key(Sno,Cno));

用户定义的元组上的约束条件:

CREATE TABLE Student(
    Sno CHAR(7) PRIMARY KEY,
    Sname CHAR(8) NOT NULL,
    Ssex char(2),
    Sage SMALLINT,
    Sdept CHAR(20),
    CHECK(Ssex='女' OR Sname NOT LIKE 'Mr.%'));//定义了Sname和Ssex之间的约束条件

3.4 CONSTRAINT完整性约束名子句

在定义表时利用约束命名子句对完整性约束条件命名,能够灵活地增加或删除一个完整性约束条件。

定义表Student,要求学号在[10000,19999]之间,姓名不能取空值,年龄小于30,性别只能是”男“或”女“,全部用约束命名子句实现。

CREATE TABLE Student(
    Sno NUMERIC(5)
        CONSTRAINT C1 CHECK(Sno BETWEEN 10000 AND 19999),
    Sname VARCHAR(20)
        CONSTRAINT C2 NOT NULL,
    Sage NUMERIC(3)
        CONSTRAINT C3 CHECK(Sage<30),
    Ssex VARCHAR(2)
        CONSTRAINT C4 CHECK(Ssex IN('男','女')),
    CONSTRAINT StudnetKey PRIMARY KEY(Sno));

在表Student上定义了5个约束条件,包括主码约束以及C1、C2、C3、C4四个列级约束。

修改表Student中的完整性限制,去掉对性别的限制,并将年龄的限制由小于30改为小于35

ALTER TABLE Student
    DROP CONSTRAINT C4;/*去掉对性别的限制条件C4*/
ALTER TABLE Student
    DROP CONSTRAINT C3;/*先删掉原来的限制条件再增加一个新的约束条件*/
ALTER TABLE Student
    ADD CONSTRAINT C3 CHECK(Sage<35);

3.5 触发器

触发器又叫做事件-条件-动作规则,当特定的系统时间发生时,对规则的条件进行检查,如果条件成立则执行规则中的动作,否则不能执行。
可以建立6种触发器,即:BEFORE INSERT、BEFORE UPDATE、BEFORE DELETE、AFTER INSERT、AFTER UPDATE、AFTER DELETE。

能够定义触发器的用户有:1)表的所有者;2)系统管理员;3)拥有创建触发器的权限,且拥有对操作对象的相应的操作权限的用户。

定义表Tab含一个INT型的Col属性,插入两条数据

CREATE TABLE Tab(Col INT);
INSERT INTO Tab VALUES(10);
INSERT INTO Tab VALUES(20);

再在其上定义触发器TRI,在对表Tab的插入和更新前检查,如果插入或更新的值在(100,1000)之间的话,将其置为50;如果值大于1000的话,则给出新值不允许大于1000的提示。

右键单击触发器,选择新建触发器,设置基本属性后点击确定

生成触发器成功

其对应的DDL为:

检测:

1)向表Tab中插入数据,执行INSERT INTO Tab VALUES(150);,结果:

除了在建立触发器之前插入的数据,新插入的数据150范围在(100,1000)之间,触发器TRI自动执行,插入的数据由150变成了50。

2)对表Tab中的数据进行更新,将20更新为1500,即执行UPDATE Tab SET Col=1500 WHERE Col=20;,结果:

对表进行查询后,发现数据并没有发生变化。说明在更新数据时,值大于1000时触发器TRI自动执行,系统报错,更新无效。

4、出现的问题及解决方案

将前面创建触发器生成的DDL:

CREATE
    TRIGGER TRI BEFORE INSERT
    OR UPDATE
        ON
        "PUBLIC".TAB FOR EACH ROW AS BEGIN IF NEW.Col > 100
        AND NEW.Col < 1000 THEN NEW.Col := 50;
END IF;

IF NEW.Col > 1000 THEN RAISE EXCEPTION 'New values can not more than 1000';
END IF;
END;

直接进行执行后,发生了下图所示的报错:

未解决。

但前面通过软件的步骤来操作是成功的,挺奇怪的。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351