mysql约束

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

约束类型

  1、 NOT NULL 约束

      该约束用于指定列不能为NULL,当插入数据时,必须要为NOT NULL列提供数据。

  2、 唯一约束

    唯一约束用于指定列的数据不能重复。

    注意:唯一约束列可以为NULL

 当指定唯一约束时,系统会自动基于唯一约束列建立索引

 3、 主键约束

  主键约束用于唯一标识表行的数据。当指定了主键约束之后,主键约束列值不能重复,并且主键约束列值不能为NULL.

  注意:当指定主键约束时,系统会自动基于主键列建立索引

  一张表只能有一个主键约束

  4、 外部键约束

  外部键约束用于定义两张表之间的关系,外部键列数据必须在主键列中存在,或者为NULL.

 5、 检查约束

  检查约束用于强制列值必须满足的条件。

注意:MySql中只有主键才能定义为 auto_increment 型

 

create table company
(
   company_id smallint not null,
   company_name varchar(10)  not null,
   primary key(company_id)
);

方式一:在创建表的时候同时创建约束

create table person
(
   id  smallint not null auto_increment,
   name varchar(10) not null,
   company_id smallint,
   //主键约束
   primary key(id),      
   //唯一约束,也可以指定约束的名称: unique  key constraint_name (name),     
   unique  key(name),   
   //外键约束,也可以指定约束的名称:constraint constraint_name foreign key(company_id) references company(company_id) 
   constraint foreign key tb_person_fk(company_id) references company(company_id)
)

方式二:创建表以后,再创建约束

create table person
(
   id  smallint not null,
   name varchar(10) not null,
   company_id smallint
)

//创建主键约束

(1)alter able person add primary key(id);
(2)alter table person add constraint primary_k primary key(id);
再将主键列设为auto_increment:

alter table person modify id smallint auto_increment;

//删除主键约束

alter table person drop primary key;

删除主键约束的时候,如果主键已经是auto_increment型,则无法删除,因为只有主键才能是auto_increment型的

约束名称可以用 show create tabletable_name命令查看 

//查看约束

SHOW CREATE TABLE tb_emp;

// 创建外键约束

(1)alter table person  add  foreign  key(company_id)  references company(company_id);
(2)alter table person  add  constraint  foreing_k  foreign key(company_id) references company(company_id);

创建外键约束以后,系统自动为外键列创建了一个key,名称可以用show create table table_name查看

用下面的方式删除外键约束后,这个key仍然存在。                                

//删除外键约束

alter table person  drop  foreign key  foreign_k;

//创建唯一约束

(1)alter table person add  unique key(name);
(2)alter table person add  constraint  unique_k unique  key(name);

//删除唯一约束索引

因为创建unique约束后,系统会自动给此列创建索引,用show create table table_name查看索引名称

alter table person drop index name;
约束实例:
# check 约束在mysql中不起作用
CREATE TABLE `tb_emp` (
  `id` INT(11) PRIMARY KEY AUTO_INCREMENT,     #主键,自动增长
  `name` VARCHAR(8) NOT NULL,     # not null, 定义的字段插入值时不能为空。
  `sex` VARCHAR(2) DEFAULT NULL CHECK(sex='男' OR sex='女'),
  `age` INT(11) DEFAULT NULL CHECK(age>18 AND age<50),
  `address` VARCHAR(200) DEFAULT NULL,
  `email` VARCHAR(100) UNIQUE,     # 邮箱,唯一约束,如果插入值,不能出现另一行的Email和当前航的email相同。
  # 数据冗余 部门三个字段占0.00001kb,那如果1W个员工,则会占据1KB,且在查询数据库的时候,会降低查询效率
  # 解决数据冗余的方法,通过一个字段就可以查询到其他相关信息
  # tb_emp里面的dept_id字段引用自tb_dept表,如果部门表里面没有id为3的部门,则这个字段的值不能为3
  # 当tb_emp表里面有dept_id为3的数据,就不能删除tb_dept表里面id为3的记录,因为有关引用
  # 外键参照的只能是主表tb_dept主键或者唯一键。
  dept_id INT REFERENCES tb_dept(id) # 部门名称
) ENGINE=INNODB DEFAULT CHARSET=utf8;

# mysql 中的外键
DROP TABLE IF EXISTS `tb_emp`;
CREATE TABLE `tb_emp` (
  `id` INT(11) PRIMARY KEY AUTO_INCREMENT,     #主键,自动增长
  `name` VARCHAR(8) NOT NULL,     # not null, 定义的字段插入值时不能为空。
  `sex` VARCHAR(2) DEFAULT NULL CHECK(sex='男' OR sex='女'),
  `age` INT(11) DEFAULT NULL CHECK(age>18 AND age<50),
  `address` VARCHAR(200) DEFAULT NULL,
  `email` VARCHAR(100) UNIQUE,     # 邮箱,唯一约束,如果插入值,不能出现另一行的Email和当前航的email相同。
  dept_id INT,
  # 定义外键
  CONSTRAINT FOREIGN KEY tb_emp_fk(dept_id) REFERENCES tb_dept(id)
) ENGINE=INNODB DEFAULT CHARSET=utf8;
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
27天前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
6月前
|
关系型数据库 MySQL
MYSQL-多表操作-外键约束
MYSQL-多表操作-外键约束
|
6月前
|
关系型数据库 MySQL
MYSQL:约束(主键约束)
MYSQL:约束(主键约束)
|
2月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
37 4
|
3月前
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
3月前
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
51 1
|
4月前
|
数据采集 关系型数据库 MySQL
在 MySQL 中使用约束
【8月更文挑战第11天】
63 0
在 MySQL 中使用约束
|
6月前
|
SQL 关系型数据库 MySQL
MySQL----约束
MySQL----约束
35 1
|
6月前
|
数据采集 关系型数据库 MySQL
MySQL数据库基础第三篇(约束)
MySQL数据库基础第三篇(约束)
|
6月前
|
关系型数据库 MySQL
MYSQL约束(自增长,以及非空约束)
MYSQL约束(自增长,以及非空约束)
下一篇
无影云桌面