chapter07_数据库的完整性_1_数据库的完整性

  • 数据库的完整性包括

    (1) 数据的正确性

    数据的合法性

    (2) 数据的有效性

    数据是否在有效范围内

    (3) 数据的相容性

    表示同一事实的两个数据应该相同

  • 完整性约束

    (1) 实体完整性约束

    主键不能为空

    (2) 参照完整性约束

    外键要么为空,要么为其他表中取值

    (3) 用户定义的完整性约束

    用户定义的规则

  • 数据完整性控制策略

    (1) 默认值 DEFAULT

    (2) 约束 UNIQUE、NOT NULL等

    使用约束优于触发器、规则、默认值

    (3) 规则 CHECK

    (4) 触发器

  • 实体完整性

    (1) 主键不能为空

    (2) 一般系统会自动在主键属性上创建唯一的索引

  • 参照完整性

    (1) 外键可以REFERENCES当前表的主键组成的某一列,且可以不止一个

    示例

      CREATE TABLE `table1` (
          `num1` int(11) NOT NULL,
          `num2` int(11) NOT NULL,
          PRIMARY KEY (`num1`)
      );
    
      CREATE TABLE `table2` (
          `num1` int(11) NOT NULL,
          `num2` int(11) NOT NULL,
          `num3` int(11) NOT NULL,
          PRIMARY KEY (`num1`),
          CONSTRAINT `fk_1` FOREIGN KEY (`num2`) REFERENCES `table1` (`num1`),
          CONSTRAINT `fk_2` FOREIGN KEY (`num3`) REFERENCES `table2` (`num1`)
      );
    
  • 参照完整性违约处理的策略

    (1) 参照关系插入元组时,被参照关系不存在相应的元组

    受限插入:拒绝插入

    递归插入:首先向被参照关系插入响应的元组,然后再插入参照关系的元组

    (2) 被参照关系删除元组时,删除的元组和被参照关系的某些元组有关联

    级联删除:参照关系和被参照关系相应的元组一并删除

    受限删除:拒绝删除

    置空值删除:删除被参照关系的元组,同时将与之关联的参照关系的元组上的值置为NULL

    (3) 参照关系更新元组

    类比 (1)参照关系插入元组 的情况

    (4) 更改被参照关系的主键值

    类比 (2) 被参照关系删除元组 的情况

    系统默认的策略是拒绝执行,但是可以手动添加策略

    例如

      CREATE TABLE `table2` (
          `id` int(11) DEFAULT NULL,
          `num` int(11) DEFAULT NULL,
           CONSTRAINT `fk` FOREIGN KEY (`id`) REFERENCES `table1` (`id`) 
           ON DELETE NO ACTION 
           ON UPDATE CASCADE
      );
    

    现在MYSQL只支持
    [ON DELETE reference_option] 和 [ON UPDATE reference option]

    其中,reference_option包括 RESTRICT | CASCADE | SET NULL | NO ACTION | SET DEFAULT

    (没彻底搞懂)这些都是针对父表的,即父表删除或父表更新时应该采取怎样的策略,好像没有针对子表插入和更新的策略……

  • 用户定义的完整性

    包括 UNIQUE, NOT NULL, CHECK, DEFAULT等

  • 触发器简介

    (1) 触发器是一种特殊的存储过程,在对表或视图进行UPDATE、INSERT或DELETE时自动执行,用编程的方法实现复杂的业务规则,比约束更精细

    (2) 触发器的优点

    1° 可以实现复杂的业务规则

    2° 比CHECK实现约束更复杂的数据完整性

    3° 可以比较数据修改前后的状态

      大部分触发器提供了引用被修改数据的能力
    

    4° 维护非规范化数据

    (3) 定义触发器

      CREATE
      TRIGGER trigger_name
      trigger_time trigger_event
      ON tbl_name 
      FOR EACH ROW
      trigger_body
    
      trigger_time: { BEFORE | AFTER }
    
      trigger_event: { INSERT | UPDATE | DELETE }
    

    示例

      CREATE TABLE `table1` (
          `id` varchar(11) DEFAULT NULL
      );
    
      CREATE TABLE `table2` (
          `id` varchar(11) DEFAULT NULL
      ); 
    
      CREATE TRIGGER insert_trigger
      AFTER INSERT ON table1
      FOR EACH ROW
      INSERT INTO table2(id) VALUES (new.id);
    

    这个触发器的作用是,每次向table1插入值的时候,如果插入成功,就自动也向table2插入值;

    (4) AFTER表示触发事件完成以后,判断触发条件是否满足;如果触发事件因为违反约束或语法错误而失败,则不执行触发器; BEFORE表示在触发事件进行以前判断触发条件是否满足,如果满足则先执行触发动作,再执行触发事件

    (5) 触发器可以分为行级触发器 FOR EACH ROW 和语句级触发器 FOR EACH STATEMENT;行级触发器在对每一个修改的元组都会触发触发器;而语句触发器只在SQL执行的时候触发触发器

    MySQL 5.7 does not support triggers using FOR EACH STATEMENT.

    (6) 一个表对于每个触发操作可以有多个触发器,同一个表上的多个触发器激活时的顺序

    1° 执行BEFORE触发器

    2° 执行SQL语句

    3° 执行AFTER触发器

    如果SQL语句有问题,将不会执行AFTER触发器

    (7) 删除触发器

      DROP TRIGGER trigger_name;
    

    删除触发器不会影响原有表,删除表时会自动删除其上的所有触发器

    (8) 触发器可以支持完整性约束的所有功能,但是开销大,在性能上不如约束、默认值、CHECK好;因此,触发器放在后面考虑,作为复杂功能用其他方法实现不了时的“大招”使用

    如果触发器所定义的表上存在约束,则在数据更改操作之前先检查约束,不符合时不需要执行触发器

  • 使用UNIQUE而不使用PRIMARY KEY的场合

    (1) 非主键的一列或列组合

    (2) 允许NULL的列

    (3) 要定义多个UNIQUE的时候(一张表UNIQUE可以有多个,PRIMARY KEY只能有一个)

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

推荐阅读更多精彩内容

  • 1. MySQL常用命令 1) mysql -h 主机名 -u 用户名 -p;登陆mysql 2) create ...
    zbcao阅读 385评论 0 0
  • 观其大纲 page 01 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 M...
    周少言阅读 3,157评论 0 33
  • MYSQL 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 MySQL基本操...
    Kingtester阅读 7,811评论 5 116
  • 数据库完整性 实体完整性 实体完整性:PRIMARY KEY列级 约束条件CREATE TABLE Student...
    iOS_愛OS阅读 782评论 0 1
  • 文/柯珂 也许,每个人从小就为自己营造了一个“小天地”。 那是属于自己的领地,不容许任何人去侵犯,小心翼翼地保护着...
    柯苛阅读 221评论 0 2