再谈表的约束

server/2024/9/22 23:25:23/

在这里插入图片描述

文章目录

  • 自增长
  • 唯一键
  • 外键

自增长

auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。
自增长的特点:

  • 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)
  • 自增长字段必须是整数
  • 一张表最多只能有一个自增长
sql>mysql> create table if not exists tt21( id int unsigned primary key auto_increment, name varchar(20) not null );
Query OK, 0 rows affected (0.22 sec)sql>mysql> desc tt21;
+-------+--------------+------+-----+---------+----------------+
| Field | Type         | Null | Key | Default | Extra          |
+-------+--------------+------+-----+---------+----------------+
| id    | int unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(20)  | NO   |     | NULL    |                |
+-------+--------------+------+-----+---------+----------------+
2 rows in set (0.06 sec)sql>mysql> insert into tt21 (name) values ('a');
Query OK, 1 row affected (0.00 sec)sql>mysql> insert into tt21 (name) values ('b');
Query OK, 1 row affected (0.00 sec)sql>mysql> insert into tt21 (name) values ('c');
Query OK, 1 row affected (0.00 sec)sql>mysql> select * from tt21;
+----+------+
| id | name |
+----+------+
|  1 | a    |
|  2 | b    |
|  3 | c    |
+----+------+
3 rows in set (0.00 sec)

如果在插入时没有设定自增值,那么默认从1开始,如果插入了一个自增值,那么后面如果没有插入自增值,就从上一个继续开始:

在这里插入图片描述

也可以自己设定一个起始值:

sql>mysql> create table tt22( id int  unsigned primary key auto_increment, name varchar(20) not null )auto_increment=500;
Query OK, 0 rows affected (0.03 sec)sql>mysql> insert into tt22 (name) values ('a');
Query OK, 1 row affected (0.01 sec)sql>mysql> insert into tt22 (name) values ('b');
Query OK, 1 row affected (0.01 sec)sql>mysql> insert into tt22 (name) values ('c');
Query OK, 1 row affected (0.01 sec)sql>mysql> select * from tt22;
+-----+------+
| id  | name |
+-----+------+
| 500 | a    |
| 501 | b    |
| 502 | c    |
+-----+------+
3 rows in set (0.00 sec)

在插入后获取上次插入的 AUTO_INCREMENT 的值(批量插入获取的是第一个值):

sql>mysql> select last_insert_id();

唯一键

一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题。

唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。

关于唯一键和主键的区别:我们可以简单理解成,主键更多的是标识唯一性的。而唯一键更多的是保证在业务上,不要和别的信息出现重复。

sql>mysql> create table stu( id char(20) unique comment '这是学生的唯一键', name varchar(32) not null );
Query OK, 0 rows affected (0.03 sec)sql>mysql> desc stu;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | char(20)    | YES  | UNI | NULL    |       |
| name  | varchar(32) | NO   |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

如果插入的id是一样的,就会插入失败:
在这里插入图片描述

唯一键可以为空:
在这里插入图片描述

外键

外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。

语法:

foreign key (字段名) references 主表()

实例:
在这里插入图片描述

主表创建:

sql>mysql> create table class(-> id int primary key,-> name varchar(32) not null-> );
Query OK, 0 rows affected (0.03 sec)

从表创建:

sql>mysql> create table student( id int unsigned primary key, name varchar(20) not null, telephone varchar(32) unique key, class_id int, foreign key(class_id) references class(id) );
Query OK, 0 rows affected (0.06 sec)

主表中含有的信息:

sql>mysql> select * from class;
+----+--------------+
| id | name         |
+----+--------------+
|  1 | 物联网101    |
|  2 | 物联网102    |
+----+--------------+
2 rows in set (0.00 sec)

在从表中插入信息:
在这里插入图片描述
在从表中插入班级id为1和2都是可以的,但是插入的班级id为3,由于外键约束,导致插入失败。

删除主表中班级id为1 的班级:
在这里插入图片描述

id为1的班级里面还有学生,由于外键约束导致删除失败。

在这里插入图片描述


http://www.ppmy.cn/server/100487.html

相关文章

AI时代下的智慧体育, 用科技赋能体育创新

在科技飞速发展的今天,人工智能(AI)已成为推动各行各业创新的重要力量。体育,作为人类文明的重要组成部分,同样在AI的浪潮中迎来了新的变革机遇。AI时代下的智慧体育,不再局限于传统的运动模式,…

axios中的baseURL与跨域问题

axios中的baseURL 01. baseURL与跨域02. axios的baseurl为相对地址03. axios的baseURL是使用绝对路径还是相对路径04. API 请求跨域05. 生产环境代理问题我理解的baseURL 01. baseURL与跨域 三种模式配置: 开发环境 .env.development测试环境 .env.production生产…

简单回归问题实战

数据表:链接: https://pan.baidu.com/s/1sSz7F_yf_JeumXcP4EjE5g?pwd753f 提取码: 753f 核心流程: import numpy as np # 计算误差函数 points是数据集中数据的位置 def compute_error_for_line_given_points(b,w,points):totalError0for i in range(0…

书生实战营-入门导-L2-Git

任务一: fork仓库、添加文件、push文件、新建pr pr链接:git_1847_introduction by Whale-Yu Pull Request #1619 InternLM/Tutorial GitHub 任务二: 新建个人笔记仓库: 新建文件: 然后github新建一个仓库&#xf…

docker compose部署rabbitmq集群,并使用haproxy负载均衡

一、创建rabbitmq的data目录 mkdir data mkdir data/rabbit1 mkdir data/rabbit2 mkdir data/rabbit3 二、创建.erlang.cookie文件(集群cookie用) echo "secretcookie" > .erlang.cookie 三、创建haproxy.cfg配置文件 global log stdout fo…

SQL每日一练-0814

今日SQL题难度:🌟☆☆☆☆☆☆☆☆☆ 1、题目要求 找出每个部门中薪资最高的员工显示部门ID、部门名称、员工ID、员工姓名以及对应的薪资 2、表和虚拟数据 现有两个表:Employees 和 Departments,记录了员工和部门信息。…

Spring Boot - 在Spring Boot中实现灵活的API版本控制(下)_ 封装场景启动器Starter

文章目录 Pre设计思路ApiVersion 功能特性使用示例配置示例 ProjectStarter Code自定义注解 ApiVersion配置属性类用于管理API版本自动配置基于Spring MVC的API版本控制实现WebMvcRegistrations接口,用于自定义WebMvc的注册逻辑扩展RequestMappingHandlerMapping的类…

【Linux】Rsync 服务环境部署

一、实验设备 服务端:172.16.1.31客户端:172.16.1.7 二、实验步骤 A 服务端 步骤1:安装(更新至最新版) yum install -y rsync 步骤2:配置文件 # 新建配置文件 vim /etc/rsyncd.conf # 添加所需配置信息…