<MySQL><复习>数据库约束

NULL:非空约束

NOT NULL

创建表时,指定某列不能为空,当插入值为空(包括未设置默认值的指定列插入)时插入失败。

以创建学生表为列:

create table student (
    id int not null,
    name varchar(20),
    score float(5,2)
    );

设置id列非空,当插入行记录id列的值为null时会报错,当插入行记录仅有name、score值时也会报错。

UNIQUE:唯一约束

UNIQUE

创建表时,指定某列不能重复出现,即表所有行记录中任意该列的值除自身外不和其他任何行记录的该列的值相同。

同样以创建学生表为例:

create table student (
    id int unique,
    name varchar(20),
    score float(5,2)
    );

对于上述学生表,若执行以下sql语句便会报错,因为id设置了UNIQUE约束,不能重复

insert into student values 
    (1, "大傻春", 30,2), 
    (2, "王旺", 29.3),
    (1, "haihai", 45.1);
DEFAULT:默认值约束

DEFAULT  值

创建表时可对列设置默认值,当插入行记录不包含该列时,自动插入默认值(插入值为null时不触发)避免该列为空,或达到简化代码的目的

create table student (
    id int,
    name varchar(20),
    score float(5,2) default 0
    );
PERIMARY KEY:主键约束

PERIMARY KEY [AUTO_INCREMENT]

创建表时,设置某列为主键,主键值不能为空,主键值不能重复,一个表仅能有一个主键

create table student (
    id int primary key,
    name varchar(20),
    score float(5,2)
    );

可搭配auto_increment使用,当掺入行记录不包括主键时,自动插入最大值+1。

FOREIGN KEY : 外键约束

FOREIGN KEY (列) REFORENCES 主表(列)

创建表时,设置某列为外键,使此表为父表的子表

  • “REFORENCES 主表(列)”中的列需在父表中具有唯一属性(主键、UNIQUE)
  • 外键中列的数据类型必须和父表中主键的数据类型相同
  • 外键可以定义多个,外键中列的个数必须和父表中列的数目相同,一一对应
create table score (
    student_id int,
    score float(5,2),
    foreign key (student) reforences student(id)
    );

设置后,外键的值必须是在主键中出现,主表不可先于子表删除

check约束

CHECK (表达式)

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值