<meta charset=”UTF-8″ />
</head>
<body>
<!– 约束
概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据
分类:
关键字:default
外键约束:用来让两张表的数据之间建立联系,保证数据的一致性和完整性
注意:约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束。
例子:
id 唯一标识 int 约束条件:主键,并且自动增长 约束关键字:primary key,auto_increment
name 姓名 varchar(10) 约束条件:不为空,并且唯一 约束关键字:not null,unique
age 年龄 int 约束条件:大于0,并且小于等于120 约束关键字:check
status 状态 char(1) 约束条件:如果没有指定该值,默认为1 约束关键字:default
gender 性别 char(1) 约束条件:无 约束关键字:无
根据上面创建表
id int primary key auto_increment comment ‘主键’,
name varchar(10) not null unique comment ‘姓名’,
age int check (age >0 and age <=120) comment ‘年龄’,
status char(1) default ‘1’ comment ‘状态‘,
–>
<!– 外键约束
概念:外键用来让两种表的数据之间建立连接,从而保证数据的一致性和完整性
注意:在数据库层面,未建立外键关联,是无法保证数据的一致性和完整性的。
添加外键
…
[constraint] [外键名称] foreign key (外键字段名) references 主表(主表列名)
);
alter table 表名 add constraint 外键名称 foreign key (外键字段名) references 主表(主表列名);
删除外键
alter table 表名 drop foreign key 外键名称;
no action:当父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。默认行为
restrict:当父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新。默认行为
cascade:当父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表中的记录
set null:当父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(这就要要求外键允许取null)
set default:父表有变更时,子表将外键列设置成一个默认的值(innodb不支持)
语法:alter table 表名 add constraint 外键名称 foreign key (外键字段名) references 主表(主表列名)on update cascade on delete cascade;
–>
</body>
</html>
原文地址:https://blog.csdn.net/m0_59745705/article/details/134731611
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_24086.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!