服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - MySQL六种约束的示例详解

MySQL六种约束的示例详解

2023-02-22 14:45绿仔牛奶_ Mysql

约束是作用于表中字段上的规则,用于限制存储在表中的数据。这篇文章主要为大家整理了一下MySQL中六种约束的用法,感兴趣的可以了解一下

什么是约束

作用于表上的规则,限制存储在表中的数据

约束分类:

约束 描述 关键字
非空约束 该字段数据不能为null NOT NULL
唯一约束 该字段数据唯一不重复 UNIQUE
主键约束 一行数据的唯一标识(非空且唯一) PRIMARY KEY
默认约束 未指定该字段值则使用默认值 DEFAULT
检查约束(8.0.16以后) 该字段值满足某一条件 CHECK
外键约束 为两张表建立连接(数据一致、完整) FOREIGN KEY

创建表示例:

?
1
2
3
4
5
6
7
CREATE TABLE info(
    `id` INT UNIQUE auto_increment PRIMARY KEY COMMENT'ID唯一标识',
    `name` VARCHAR(10) NOT NULL UNIQUE COMMENT'姓名',
    `age` INT CHECK(age > 0 && age < 120) COMMENT '年龄',
    `status` CHAR(1) DEFAULT'1' COMMENT'状态',
    `gender` CHAR(1) COMMENT'性别'
)COMMENT '用户信息表';

外键约束

外键通常用来为两张表建立连接,两张利用外键连接的表被称为父子表。

子表当中会设定一个外键字段用于关联父表的主键字段

即拥有外键的表是子表(从表),该外键对应另一个表的主键这个表称之为父表

如果没有设置外键,仅仅是将子表开了一个字段对应上了父表的主键字段在mysql层面是依旧没有任何关系的。此时两个表仅存在逻辑关系,无法保证数据的完整性和一致性

创建外键语法:

?
1
2
3
4
5
6
7
8
9
-- 在创建表时创建
CREATE TABLE son(
    ...
    CONSTRAINT [外键名称] FOREIGN KEY(外键字段名) REFERENCES 主表名(主表主键字段名)
);
-- 创建表后为表添加主键
ALTER TABLE 表名  ADD CONSTRAINT 外键名称 FOREIGN KEY(外键字段名) REFERENCES 主表(主表主键字段名)
-- 删除外键
alter table 表名 drop foreign key 外键名称;

创建示例:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 父表
CREATE TABLE father(
    `id` INT auto_increment PRIMARY KEY COMMENT'父表ID',
    `name` VARCHAR(20) NOT NULL COMMENT'姓名',
    `password` VARCHAR(20) DEFAULT(0000)
);
INSERT INTO father VALUES(null,'小三','1234'),(null,'小四','1234'),(null,'小五','1234'),(null,'小六','1234');
# 子表
CREATE TABLE son(
    `id` INT auto_increment PRIMARY KEY COMMENT'子表ID',
    `status` varchar(10) COMMENT '状态',
    `fa_id` INT COMMENT'外键',
    CONSTRAINT fk_father_son FOREIGN KEY(fa_id) REFERENCES father(id)
);
INSERT INTO son VALUES(null,'活',2),(null,'活',3),(null,'死',3),(null,'活',2);

上述示例 子表设置了外键,字段名为fa_id并关联到了父表主键id,外键名称为fk_father_son

创建完成后,我们添加几组数据。将几个son添加到表中,并设置外键字段属性为某个father。比如(null,‘活’,3),那么此时如果我们尝试去删除父表id=3的这一行数据,就会提示错误。因为两个表已经在mysql层面上进行了关联

总结:

  • 从表的外键通常是主表的主键
  • 从表中外键的类型必须与主表中的主键类型一致
  • 主表数据发生变化时应注意从表数据的一致性问题

到此这篇关于MySQL六种约束的示例详解的文章就介绍到这了,更多相关MySQL六种约束内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/yuqu1028/article/details/128875020

延伸 · 阅读

精彩推荐
  • Mysqlmysql datetime查询异常问题解决

    mysql datetime查询异常问题解决

    这篇文章主要介绍了mysql datetime查询异常问题解决的相关资料,这里对异常进行了详细的介绍和该如何解决,需要的朋友可以参考下...

    服务器之家4432020-06-30
  • MysqlMySQL系列之一 MariaDB-server安装

    MySQL系列之一 MariaDB-server安装

    本文主要介绍了MariaDB-server安装的几种方式,文中通过代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    生生不息.连绵不绝9322021-08-27
  • MysqlMySql 错误Incorrect string value for column

    MySql 错误Incorrect string value for column

    能使用中文进行搜索,但是insert into 中文是可以的。我的数据库和数据表中所有的charset都是设置的utf8。 ...

    mysql教程网3842019-11-12
  • MysqlMySQL 表的垂直拆分和水平拆分

    MySQL 表的垂直拆分和水平拆分

    这篇文章主要介绍了MySQL 表的垂直拆分和水平拆分,文中讲解非常细致,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下...

    看云4432020-07-31
  • Mysqlmysql登录报错提示:ERROR 1045 (28000)的解决方法

    mysql登录报错提示:ERROR 1045 (28000)的解决方法

    这篇文章主要介绍了mysql登录报错提示:ERROR 1045 (28000)的解决方法,详细分析了出现MySQL登陆错误的原因与对应的解决方法,需要的朋友可以参考下 ...

    信仰5682020-06-03
  • MysqlMySql中sql语句执行过程详细讲解

    MySql中sql语句执行过程详细讲解

    天天和数据库打交道,一天能写上几十条 SQL 语句,但你知道我们的系统是如何和数据库交互的吗?下面这篇文章主要给大家介绍了关于MySql中sql语句执行过程详...

    喜欢猪猪10062023-02-22
  • MysqlMySQL中复制数据表中的数据到新表中的操作教程

    MySQL中复制数据表中的数据到新表中的操作教程

    这篇文章主要介绍了MySQL中复制数据表中的数据到新表中的操作教程,文中分为新表存在和新表不存在两种情况来讲,需要的朋友可以参考下 ...

    kumu_Linux5122020-06-02
  • Mysqlmysql 导出CSV文件 并带表头的方法

    mysql 导出CSV文件 并带表头的方法

    下面小编就为大家带来一篇mysql 导出CSV文件 并带表头的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    jingxian9432020-07-24