如何在MySQL中设置外键约束以及外键的作用?
外键的作用:外键主要用来保证数据的完整性和一致性,便于关系数据的日常维护。是两张关系表中的主表数据修改或删除是自动操作字表中的数据。(外键并不是费用不可,通过程序逻辑上的操作完全可以替代)
注意事项:
1、两个表必须是InnoDB表,MyISAM表暂时不支持外键
2、如果在较早的版本(4.1.2以前)则需要显示建立外键列必须建立了索引
3、外键关系的两个表的列必须是数据类型相似。比如int和tinyint可以,而int和char则不可以
外键约束使用最多的两种情况:
1)父表更新时子表也更新,父表删除时如果子表有匹配的项,删除失败;
2)父表更新时子表也更新,父表删除时子表匹配的项也删除。
前一种情况,在外键定义中,用ON UPDATE CASCADE ON DELETE RESTRICT;
后一种情况,可以使用ON UPDATE CASCADE ON DELETE CASCADE。
举例说明:用最常见的场景:文章表,和分类表;
创建外键约束:
ALTER TABLE `article`ADD CONSTRAINT `fk_1` FOREIGN KEY (`category_id`) REFERENCES `category` (`id`);
现在删除分类表中的一条数据:
文章表添加一条数据:
这样是不是就保证了文章表里的分类ID 都能在分类表找到对应的名称啦?
下面我们删除外键重新创建:
mysql怎么使用检查约束?
MySQL使用check约束的方法:
1、如果要设置CHECK约束的字段范围小,并且比较容易列举全部的值,可以将该字段的类型设置为enum类型或set类型。
2、如果需要设置CHECK约束的字段范围大,且列举全部值比较困难,使用触发器来代替约束实现数据的有效性。
mysql的contest怎么设置默认约束?
可以使用如下的SQL语句创建一个TEXT类型的字段并设置CHECK约束,要求该字段内容长度必须大于等于100个字符:
```
CREATE TABLE table_name (
col_name TEXT CHECK (LENGTH(col_name) >= 100)
);
```
其中,`table_name`为表名,`col_name`为字段名。这样就可以在该字段上设置默认约束,确保输入的内容长度不会低于100个字符。
alter table 表名 modify 字段名 default 默认值; 试试alter table user modify (status int default 1)

