MySQL-约束

  • 介绍:

    ​ 顾名思义,约束是一种限制,它的限制是针对表中列的数据的,以此来确保表中数据的完整性、有效性和唯一性。

    ​ 约束作用于表中字段上,可在创建/修改表的时候添加约束

  • 分类:

约束描述关键字
非空约束限制该字段的数据不能为NULLNOT NULL
唯一约束保证该字段的所有数据都是唯一、不重复的UNIQUE
主键约束主键是一行数据的唯一标识,要求非空且唯一PRIMARY KEY
默认约束保存数据时,如果未指定该字段的值,则采用默认值DEFAULT
检查约束保证字段值满足某一个条件CHECK
外键约束用来让两张表的数据之间建立连接,保证数据的一致性和完整性FOREIGN KEY
  • 演示

    • 要求
    字段名字段含义字段类型约束条件
    idID唯一标识int主键,并且自动增长
    name姓名varchar(10)不为空,并且唯一
    age年龄int大于0,并且小于等于120
    status状态char(1)如果没有指定该值,默认为1
    gender性别char(1)
    • 代码
    CREATE TABLE heima(
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT 'ID唯一标识',
        name VARBINARY(10) NOT NULL UNIQUE COMMENT '姓名',
        age INT CHECK ( age > 0 && age <= 120 ) COMMENT '年龄',
        status CHAR(1) DEFAULT '1' COMMENT '状态',
        gender CHAR(1) COMMENT '性别'
    )comment '约束演示';
    
    • 外键约束

      • 介绍:外键用于在两张表之间建立连接,以此保证数据的一致性和完整性。

      • 语法:

      /*
      	添加外键
      	"外键字段名"指本表中用于做外键的字段,"主表"指与本表关联的目标表,"主表列名"指目标表中的目标字段
      */
      CREATE TABLE 表名(	#创建数据表阶段添加外键
      	字段名 数据类型,
          ...
          [CONSTRAINT] [外键名称] FOREIGN KEY(外键字段名) PEFERENCES 主表(主表列名)
      );
      ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY(外键字段名) REFERENCES 主表(主表列名);	#数据表创建完成之后的外键添加
      /*
      	删除外键
      */
      ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
      
      • 删除/更新行为

        • 语法
        ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名(主表字段名) ON UPDATE 行为 ON DELETE 行为;
        
        • 行为列表
        行为说明
        NO ACTION当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。(与RESTRICT相同)
        RESTRICT(与NO ACTION相同)
        CASCADE当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表中的记录。
        SET NULL当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(这就要求该外键允许取null)。
        SET DEFAULT父表有变更时,子表将外键列设置成一个默认的值 (Innodb1不支持)

  1. MySQL存储引擎中的其中一种。 ↩︎

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL-xmind 是一种将 MySQL 数据库架构可视化为思维导图的工具。它可以帮助开发人员更好地理解和管理数据库结构。 使用 MySQL-xmind,我们可以通过图形化的方式表示数据库中的表、字段、关系和约束等元素。这样做可以使得数据库设计更加直观、易于理解。通过思维导图的形式,我们可以清楚地看到表之间的关系,如外键约束和关联关系。这对于开发人员在编写 SQL 查询和构建复杂查询时非常有帮助,因为他们可以更轻松地理解表之间的连接和关联。 此外,MySQL-xmind 还可以帮助我们进行数据库的维护和优化。我们可以使用思维导图来查看表的索引、主键和其他约束,从而更好地了解数据库的性能和结构。通过检查思维导图,我们可以发现潜在的问题,如冗余数据、不合理的索引或缺失的关联。 一些功能强大的特性,如批量生成 SQL 语句、导出导入数据库结构等,也使得 MySQL-xmind 成为一个非常实用的工具。它允许我们快速生成 SQL 脚本,以便在不同的环境中部署数据库结构。同样地,我们可以将数据库结构导出为思维导图,方便与团队成员共享和讨论。 总之,MySQL-xmind 是一个方便实用的工具,可以对 MySQL 数据库的结构进行可视化管理和优化。它帮助了开发人员更好地理解数据库的设计和关系,并提供了一些非常有用的功能,如批量生成 SQL 语句和导出导入数据库结构等,使得数据库管理更加高效和便捷。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值