DDL语言---常见约束

  1. 常见约束

    • 含义:限制表中的数据,为了保证数据的准确性与可靠性

    • 分类:六大约束
      not null:非空,保证该字段值不可为空
      default: 默认值约束,用于保证该字段有默认值
      primary key:主键,保证字段值唯一且非空
      unique:唯一,保证该字段唯一,可以为空
      check: 检查约束
      foreign key: 限制两个表关系,保证该字段值必须来自主表的关联列的值
      (在从表添加外键约束,用于引用主表中的某列值)

    • 约束添加分类:

      1. 列级约束:外键约束无效果

      2. 表级约束:除了非空和默认都支持

    • 主键和唯一的区别:
      保证唯一性 是否允许为空 一个表中的个数 是否允许组合
      主键 是 不允许 至多一个 允许(只有组合的字段值都相同时报错)
      唯一 是 允许 可以多个 允许(只有组合的字段值都相同时报错)

    • 外键:

      1. 在从表设置关系
      2. 主从表字段类型一致,名称可不同
      3. 关联列必须为主键或者唯一键
      4. 先插入主表数据
      5. 先删除从表数据
    • 列级约束和表级约束:
      位置 支持的约束类型 是否可以起名(constraint 约束名)
      列级约束 列后面 语法都支持,但外键没有效果 不可以
      表级约束 所有列下面 非空和默认不支持 可以

# 1. 创建表时添加约束
CREATE DATABASE students;
## 1.1 列级约束
USE students;
CREATE TABLE stuinfo(
	id INT PRIMARY KEY,
	stuName VARCHAR(20) NOT NULL UNIQUE, ## 添加多个约束
	gender CHAR(1) CHECK(gender='男' OR gender='女'),
	seat INT UNIQUE,
	age INT DEFAULT 18,
	majorId INT REFERENCES major(id)  ##无效果
);
DESC stuinfo

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值