【百日精通JAVA | SQL篇 | 第四篇】约束

SQL这一块没什么难度,主要是一个熟练度,稍微上点难度的地方,其实在于查,比较复杂,涉及到很多问题。

指定列插入

使用指定列插入的时候,未被指定的列使用默认值进行存储,默认值为空。

默认值设置

default关键字,在设置字段时,可以对其默认值进行修改

Primary Key 主键

主键约束,主键就是一条数据-身份标识

通过这个约束,来指定某个列作为主键

1)非空

2)不能重复

一个表,只能有一个主键,但是一个主键可以对应多个列,我们称之为联合主键。

Primary Key auto_increment 自增主键

主键,往往是一个整数类型的id,要求不能重复。允许客户端,在插入数据时候,不手动指定主键的值,而是交给MYSQL自行分配,确保分配出来的这个主键的值,是和之前不重复的。

primary key auto_increment 自增主键 意味着数据库自行分配一个键值.

那如果再次插入数据的时候,id自动分配的是4还是11?

数据库记录了,当前表中id最大值,此时id自动分配的是11.

前面的4 5 6 7... 浪费了也无所谓,空间非常大,即便我们浪费几千、几万个也无所谓

一共可以表示几十亿个数据。

mysql服务器会维护这样的最大值

如果mysql是一个单个节点的系统,按照上述自增主键的策略,是没问题的

如果mysql是一个分布式系统,搞了好几个主机,每个主机都有mysql,让他们相互配合,此时,自增主键,就无法保证唯一性了。

注意:每个主机存储时都只会存储最大数值的id,那么此时就会出现重复

FOREIGN KEY: 外键约束

当前这个表的哪一类要受到约束

在这个代码中,需要明确交代,哪个表的那一列要受到哪一个表的那一列的约束

sql 复制代码
create table student(
studentId int primary key auto_increment,
name varchar(20),
classId int,
foreign key (classId) references class(classId));

插入或者修改子表受约束的这一列数据,就需要保证插入/修改后的结果,得在父表中存在!!

删除/修改 父表中的记录,就需要看看这个记录是否在子表中被使用了,如果被使用了,则不能进行修改或者删除。约束是双向的

索引

设置外键的时候,就会导致在操作子表的时候,频繁访问父表

这一个查询操作,是很耗时间的,为了加快查询速度,如果父表的ID这一列带有索引的话,就很好了

索引:相当于页码,我们提前知道这个id在书上第几页,直接翻到即可,primary key和unique都带有索引,自动创建索引,因此没有索引无法创建外键

相关推荐
ModelWhale42 分钟前
“大模型”技术专栏 | 和鲸 AI Infra 架构总监朱天琦:大模型微调与蒸馏技术的全景分析与实践指南(上)
人工智能·大模型·大语言模型
麦兜*2 小时前
Spring Boot集成方案 + Elasticsearch向量检索,语义搜索核弹
java·spring boot·python·spring·elasticsearch·spring cloud·系统架构
歪歪1002 小时前
HTML 如何转 Markdown
开发语言·chrome·python·程序人生·html
auspicious航2 小时前
PostgreSQL 高可用与负载均衡
数据库·postgresql
Absinthe_苦艾酒2 小时前
JVM学习专题(四)对象创建过程
java·jvm·后端
小坏坏的大世界2 小时前
C++中多线程和互斥锁的基本使用
开发语言·c++
lxmyzzs2 小时前
【图像算法 - 08】基于 YOLO11 的抽烟检测系统(包含环境搭建 + 数据集处理 + 模型训练 + 效果对比 + 调参技巧)
人工智能·yolo·目标检测·计算机视觉
路由侠内网穿透3 小时前
本地部署 SQLite 数据库管理工具 SQLite Browser ( Web ) 并实现外部访问
运维·服务器·开发语言·前端·数据库·sqlite
霖003 小时前
ZYNQ实现FFT信号处理项目
人工智能·经验分享·神经网络·机器学习·fpga开发·信号处理
王者鳜錸3 小时前
PYTHON从入门到实践-18Django模版渲染
开发语言·python·django