深入Mysql-03-MySQL 表的约束与数据库设计

文章目录

  • 数据库约束的概述
    • 约束种类
      • 主键约束
      • 唯一约束
      • 非空约束
      • 默认值
      • 外键约束
  • 表与表之间的关系
  • 数据库设计

数据库约束的概述

对表中的数据进行限制,保证数据的正确性、有效性和完整性。一个表如果添加了约束,不正确的数据将无法插入到表中。

约束种类

约束名约束关键字
主键primary key
唯一unique
非空not null
外键foreign key
检查约束check 注:mysql 不支持

主键约束

用来唯一标识数据库中的每一条记录

  • 主键是给数据库和程序使用的,不是给最终的客户使用的。所以主键有没有含义没有关系,只要不重复,非空就行。

创建主键:

  1. 在创建表的时候给字段添加主键
    字段名 字段类型 PRIMARY KEY
  2. 在已有表中添加主键
    ALTER TABLE 表名 ADD PRIMARY KEY(字段名);

代码示例:

create table stu (id int primary key,name varchar(20),age int
)

在这里插入图片描述
删除主键约束:
alter table stu drop primary key;
在这里插入图片描述
在这里插入图片描述
主键自增:
主键如果让我们自己添加很有可能重复,我们通常希望在每次插入新记录时,数据库自动生成主键字段的值
将stu表中的主键进行添加操作:
alter table stu add primary key(id)
在这里插入图片描述
添加主键自增操作:
ALTER TABLE stu MODIFY id INT AUTO_INCREMENT;
插入几条数据看看效果:

-- 插入数据
insert into stu (name,age) values ('小乔',18); 
insert into stu (name,age) values ('大乔',20);
-- 另一种写法
insert into stu values(null,'周瑜',35);

在这里插入图片描述
可以看到我们的主键id字段是逐渐递增的。

修改自增长的默认值起始值:

  • 创建表时指定起始值
CREATE TABLE 表名(列 名 int primary key AUTO_INCREMENT
) AUTO_INCREMENT=起始值;
-- 指定起始值为 1000 
create table stu1 (id int primary key auto_increment, name varchar(20)
) auto_increment = 1000;insert into stu1 values (null, '孔明');
select * from stu1;

在这里插入图片描述

  • 创建好以后修改起始值
ALTER TABLE 表名  AUTO_INCREMENT=起始值;
alter table stu1 auto_increment = 2000;
insert into stu1 values (null, '刘备');

在这里插入图片描述
注意: delete删除的记录对自增长没有影响,但是使用truncate删除记录时,自增长会重新开始。

唯一约束

表中某一列不能出现重复的值

字段名 字段类型 UNIQUE
  • 创建一个stu2表
create table stu2 (id int,name varchar(20) unique
)
  • 插入一条数据
insert into stu2 values (1, '张三');
  • 插入一条同样的数据
insert into stu2 values (1, '张三');

在这里插入图片描述
出现了错误: Duplicate entry '张三' for key 'name'

非空约束

某一列不能为 null

字段名 字段类型  NOT NULL
  • 创建一个stu3表
create table stu3(id int,name varchar(20) not null, gender char(1)
)
  • 添加一个数据
insert into stu3 values (1,'张三疯','男');
  • 添加一个name为null的数据
insert into stu3 values (2,null,'男');

出现了错误:Column 'name' cannot be null

默认值

字段名 字段类型  DEFAULT 默认值
  • 创建一个stu4表
create table stu4 ( id int,name varchar(20),address varchar(20)	default '广州'
)
  • 添加一条默认地址数据
insert into stu4 values (1, '李四', default); 
  • 添加一个非默认地址的数据
insert into stu4 values (3, '李四光', '深圳');

在这里插入图片描述

外键约束

创建一个员工表emp

CREATE TABLE emp (id INT PRIMARY KEY AUTO_INCREMENT,NAME VARCHAR(30),age INT,dep_name VARCHAR(30),dep_location VARCHAR(30)
);-- 添加数据
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('张三', 20, '研发部', '广州');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('李四', 21, '研发部', '广州'); 
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('王五', 20, '研发部', '广州');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('老王', 20, '销售部', '深圳'); 
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('大王', 22, '销售部', '深圳'); 
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('小王', 18, '销售部', '深圳');

在这里插入图片描述
出现了大量冗余数据,解决方案就是进行分表

  1. 创建一个部门表
create table department(id int primary key auto_increment,dep_name varchar(20),dep_location varchar(20)
);
  1. 创建一个员工表
-- 创建员工表(id,name,age,dep_id)
-- 多方,从表
create table employee(id int primary key auto_increment,name varchar(20),age int,dep_id int	-- 外键对应主表的主键
)
  1. 添加俩个部门
insert into department values(null, '研发部','广州'),(null, '销售部', '深圳'); 
  1. 添加一些员工
INSERT INTO employee (NAME, age, dep_id) VALUES ('张三', 20, 1);
INSERT	INTO	employee	(NAME,	age,	dep_id)	VALUES	('李四',	21,	1);
INSERT	INTO	employee	(NAME,	age,	dep_id)	VALUES	('王五',	20,	1);
INSERT	INTO	employee	(NAME,	age,	dep_id)	VALUES	('老王',	20,	2);
INSERT	INTO	employee	(NAME,	age,	dep_id)	VALUES	('大王',	22,	2);
INSERT	INTO	employee	(NAME,	age,	dep_id)	VALUES	('小王',	18,	2);
  1. 查询员工和部门
    在这里插入图片描述
    在这里插入图片描述
    这里我们可以看到部门id对应有部门信息,但是这里我们可以查润一条当前部门表不存在的id数据,这就要通过外键约束来解决了。
  • 创建表的时候添加外键: [CONSTRAINT] [外键约束名称] FOREIGN KEY(外键字段名) REFERENCES 主表名(主键字段名)
  • 已有表增加外键:ALTER TABLE 从表 ADD [CONSTRAINT] [外键约束名称] FOREIGN KEY (外键字段名) REFERENCES 主表(主键字段名);

这里我们已经创建了表,那么我们使用第二种方式来创建外键约束。

alter table employee add constraint emp_depid_fk foreign key (dep_id) references department(id)

在这里插入图片描述
这里可以看到当我们赋予外键约束的时候无法创建出部门表里面没有的id记录。

删除外键:

ALTER TABLE 从表  drop foreign key 外键名称;
-- 删除 employee 表的 emp_depid_fk 外键
alter table employee drop foreign key emp_depid_fk;

外键的级联:
重新添加外键约束:

alter table employee add constraint emp_depid_fk foreign key (dep_id) references department(id);

当我们想改以下部门表的id时,会出现如图问题。
在这里插入图片描述
因此我们需要进行级联操作(在修改和删除主表的主键时,同时更新或删除副表的外键值)。

级联操作语法描述
ON UPDATE CASCADE级联更新,只能是创建表的时候创建级联关系。更新主表中的主键,从表中的外键列也自动同步更新
ON DELETE CASCADE级联删除

示例:


drop table employee;create table employee(
id int primary key auto_increment, name varchar(20),
age int,
dep_id int,	-- 外键对应主表的主键
-- 创建外键约束
constraint emp_depid_fk foreign key (dep_id) references department(id) on update cascade on delete cascade
)INSERT INTO employee (NAME, age, dep_id) VALUES ('张三', 20, 1);
INSERT INTO employee (NAME, age, dep_id) VALUES ('李四', 21, 1); 
INSERT INTO employee (NAME, age, dep_id) VALUES ('王五', 20, 1);INSERT INTO employee (NAME, age, dep_id) VALUES ('老王', 20, 2); 
INSERT INTO employee (NAME, age, dep_id) VALUES ('大王', 22, 2); 
INSERT INTO employee (NAME, age, dep_id) VALUES ('小王', 18, 2);

这时,我们对部门表进行删除操作。

drop table department;

在这里插入图片描述
出现了错误,无法删除或更新父行:外键约束失败。
我们对部门表进行更新操作来检测级联更新是否成功。

update department set id=10 where id=1; 

在这里插入图片描述
在这里插入图片描述
这里我们可以看到所有的id等于1的都被修改为10了。
最后我们删除部门号为10的来检测我们的级联删除是否成功。

delete from department where id=10;

在这里插入图片描述
可以看到我们的级联删除约束也是成功的。

表与表之间的关系

表与表之间的三种关系
一对多:最常用的关系 部门和员工(一个部门有多个员工)
多对多:学生选课表和学生表, 一门课程可以有多个学生选择,一个学生选择多门课程
一对一:相对使用比较少。员工表 简历表, 公民表 护照表

数据库设计

  1. 数据规范化
    建立科学的,规范的数据库就需要满足一些规则来优化数据的设计和存储,这些规则就称为范式。
  2. 三大范式
    目前关系数据库有六种范式: 第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、巴斯-科德范式(BCNF)、第四范式(4NF)和第五范式(5NF,又称完美范式)。
  • 1NF: 第一范式每一列不可再拆分,称为原子性。
  • 2NF: 第二范式就是在第一范式的基础上所有列完全依赖于主键列。
  • 3NF: 任何非主列不得传递依赖于主键。

欢迎java热爱者了解文章,作者将会持续更新中,期待各位友友的关注和收藏,另外对编程感兴趣的友友们可以加以下群共同学习。群号:127871664

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/49145.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

go-kratos 学习笔记(3) google buf 管理proto

google buf 管理proto,以及从新归档文件的目录结构 什么是 BSR? BSR 将 Protobuf 文件作为版本化模块进行存储和管理,以便个人和组织可以轻松使用和发布他们的 API。 BSR 带有可浏览的 UI、依赖项管理、API 验证、版本控制、生成的文档以及…

智能图像信息提取(飞桨OCR+ERNIE-Layout)

嘿,技术大佬们,今天我要分享的是一个超级棒的OCR技术方案,它结合了飞桨OCR和ERNIE-Layout,绝对是图像信息提取的利器! 线上体验地址:智能图像信息提取(飞桨OCRERNIE-Layout) 它基于ERNIE -Layout和多版本Pa…

稳居中科院2区的SCIEI双检索期刊,听说一投就中!

IEEE TRANSACTIONS ON ELECTRON DEVICES,中科院2区,JCR Q2, SCI&EI双检索期刊,年发文量在1000篇左右,且大有继续扩刊的走向。有投稿经验的作者反馈,比较容易被录用。 期刊信息 IEEE TRANSACTIONS ON ELECTRON DE…

决策树:简单而强大的机器学习算法

在机器学习的众多算法中,决策树(Decision Tree)以其直观易懂和易于实现的特点,成为了许多初学者的首选。决策树不仅在分类和回归问题中表现出色,还能提供易于解释的模型,帮助我们理解数据中的模式。本文将介…

Python 机器学习求解 PDE 学习项目——PINN 求解一维 Poisson 方程

本文使用 TensorFlow 1.15 环境搭建深度神经网络(PINN)求解一维 Poisson 方程: − Δ u f in Ω , u 0 on Γ : ∂ Ω . \begin{align} -\Delta u & f \quad & \text{in } \Omega,\\ u & 0 \quad & \text{on } \Gamma:\partial \Om…

c语言——运算符

一.运算符的简介 1.运算符的定义:运算符就是在c语言中程序执行运算的逻辑符号。 优先级 运算符 名称或含义 使用形式 结合方向 说明 1 [] 数组下标 数组名[常量表达式] 左到右 -- () 圆括号 (表达式)/函数名(形参表) -- . 成员选择&am…

【NLP】提升文本生成多样性的实用方法

比如用T5模型,训练数据是inputText-outputText格式,预测时do_sample=False # 预测代码from transformers import TFAutoModelForSeq2SeqLM from transformers import AutoTokenizercheckpoint_local = "./path/" tokenizer = AutoTokenizer.from_pretrained(check…

【复读EffectiveC++21】条款21:必须返回对象时,别妄想返回其reference

条款21:必须返回对象时,别妄想返回其reference 此条款,也我刚刚工作时踩过的坑,一个功能总是莫名奇妙的数据丢失,调查的时候就是返回值指针总是在特定逻辑下返回NULL,就是因为我返回的是一个局部变量。 跟…

css属性Clip-path

clip-path 允许你定义一个元素的可视区域的剪切形状。换句话说,你可以使用这个属性来裁剪或隐藏元素的一部分,使其只显示特定形状的区域,比如圆形、椭圆形、多边形或更复杂的 SVG 路径。 基本用法 clip-path 可以接受多种值,包括…

非对称加密算法RSA的OpenSSL代码实现Demo

目录 1 RSA简介 1.1 RSA算法介绍 1.2 RSA算法的速度与安全性 1.3 RSA存储格式 1.3.1 PKCS#1 标准主要用于 RSA密钥,其RSA公钥和RSA私钥PEM格式 1.3.2 PKCS#8 标准定义了一个密钥格式的通用方案,其公钥和私钥PEM格式 2 OpenSSL代码实现 2.1 生…

WSL 2 Oracle Linux 9.1 安装配置

文章目录 环境使用体验安装 Oracle Linux 9.1修改默认存储路径默认 root 用户登录启用 systemd启用 SSH 连接WSL 无法 ping 通宿主机和域名WSL 使用主机代理(测试通过)WSL 常用命令 环境 OS:Win11 24H2 (OS 内部版本26120.1252) wsl --versio…

闭着眼就能学会的装饰器

目录 一,闭包 1,闭包函数含义以及三要素 2,定义一个简单的闭包 二,装饰器 1,装饰器的作用场景以及特点 2,定义一个简单的装饰器 1,需求1 2,需求2 三,装饰器的实…

初学51单片机之指针基础与串口通信应用

开始之前推荐一个电路学习软件,这个软件笔者也刚接触。名字是Circuit有在线版本和不在线版本,这是笔者在B站看视频翻到的。 Paul Falstadhttps://www.falstad.com/这是地址。 离线版本在网站内点这个进去 根据你的系统下载你需要的版本红线的是windows…

华盈生物-“表面等离子共振(SPR)技术如何进行靶点验证:揭秘靶点锁定的科学魔法”

在药物开发和生物研究中,靶点验证是一个至关重要的步骤。表面等离子共振(SPR)技术以其高灵敏度和实时监测能力,成为了靶点验证的理想工具。今天,我们将揭示SPR技术在靶点验证中的神奇应用,让我们一起看看它…

第九讲:POU与变量基础

POU(Program Organization Unit)的分类 一、定义及分类 POU即程序组成单元 二、三种POU的作用 1、功能/功能快:看作算法 功能块的POU是比较复杂的指令 三、功能块POU和功能POU的区别 1、理解功能POU(对比) 不添加实例名,就不需要去建立变量,所以就不会占到内存。 因…

算法题目整合4

文章目录 122. 大数减法123. 滑动窗口最大值117. 软件构建124. 小红的数组构造125. 精华帖子126. 连续子数组最大和 122. 大数减法 题目描述 以字符串的形式读入两个数字,编写一个函数计算它们的差,以字符串形式返回。输入描述 输入两个数字&#xff…

物联网专业创新人才培养体系的探索与实践

一、引言 随着物联网(IoT)技术的迅猛发展,物联网领域的人才需求日益增加。物联网技术作为新一轮信息技术革命的核心,已经渗透到社会生活的各个领域,对推动经济转型升级、提升国家竞争力具有重要意义。因此&#xff0c…

VUE之---slot插槽

什么是插槽 slot 【插槽】, 是 Vue 的内容分发机制, 组件内部的模板引擎使用slot 元素作为承载分发内容的出口。slot 是子组件的一个模板标签元素, 而这一个标签元素是否显示, 以及怎么显示是由父组件决定的。 VUE中slot【插槽】…

Postman的高级功能

Postman是一款功能强大的API测试工具,它提供了许多高级功能来帮助开发者和测试人员更高效地进行API测试和开发。以下是Postman在API测试中的一些高级功能: 1. 集合和文件夹 集合:用于组织相关的API请求。文件夹:在集合内部进一步…

Huffman编码和译码

Huffman编码(Huffman Coding),又称霍夫曼编码或赫夫曼编码,是一种用于无损数据压缩的熵编码(权编码)算法,由大卫霍夫曼(David A. Huffman)在1952年发明。Huffman编码属于可变字长编码(VLC)的一种,其基本思想是根据字符在数据中出现的频率来分配不同长度的编码,出现…