mysql约束

mysql约束

简介:

约束是作用于表中字段上的规则,用于限制存储在表中的数据。

目的:保证数据库中数据的正确、有效性和完整性。

分类:

注意:

约束是作用于表中字段上的,可以在创建表/修改表的时候添加约束。

补充:mysql主键策略:

  • 主键自增
  • uuid做主键
  • 雪花算法做主键

自增的优点:

1.存储空间小

2.插入和查询性能高

自增的缺点:

1.int的范围可能不够大(但我觉得等数据到上亿级别,大部分情况下都要做分库分表了吧...)

2.当要做数据迁移的时候,会很麻烦,主键容易冲突

3.id自增,自身的业务增长情况很容易被别人掌握

4.自增在高并发的情况下性能不好

UUid的优点:

1.独一无二,几乎不会重复

2.数据合并很方便(主键不会冲突)

3.业务增长数据不会被轻易察觉

UUid的缺点:

1.生成UUid花的时间比较多

2.存储空间大

3.数据库存储UUid作为主键花的时间很多,消耗的性能也很多(因为数据库的B+数结构)

雪花算法:

是由符号位(1bit)+ 时间戳(41bit)+机器码(10bit)+序列号位(12bit) 一共64bit组成。

  • 符号位(1 bit):不使用,因为二进制中最高位是符号位,1表示负数,0表示整数,生成的ID一般都是正数,所以最高位固定为0;
  • 时间戳位(41 bit):用来记录时间戳,毫秒级。41位可以表示2 ^ {41}-1个数字,如果只用来表示正整数(计算机中正数包含0),可以表示的数值范围是:0至2 ^ {41}-1,减1是因为可表示的数值范围是从0开始算的,而不是1。也就是说41位可以表示2^{41}-1个毫秒的值,转化成单位年差不多是69年;
  • 工作进程位(10bit):工作机器ID,用来记录工作机器ID。可以部署 2 ^ {10} = 1024个节点,包括5位datacenterId和5位workerId。5位(bit)可以表示的最大正整数是2^{5}-1 = 31,即可以用0、1、2、3 ... 31这32个数字,来表示不同的datacenterId或workerId;
  • 序列号位(12bit):序列号,用来记录同毫秒内产生的不同ID。12位可以表示的最大正整数是2^{12}-1 = 4095,即可以用0、1、2、3 ... 4094 这4095个数字,来表示同一机器同一时间截(毫秒)内产生的4095个ID序号
    SnowFlake可以保证所有生成的ID按时间趋势递增,整个分布式系统内不会产生重复ID(因为有 datacenterId 和 workId来做区分)。
    所以他会有以下优点:
    1.不会重复
    2.有序,不会造成空间浪费和胡乱插入影响性能
    3.生成很快特别是比UUid快的多
    4.相比UUid更小

外键约束:

作用:用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。

注意:外键链接的两张表,只是在逻辑上存在这样一层关系;在数据库层面,并未建立外键关联,所以是无法保证数据的一致性和完整性的

语法:

添加外键

sql 复制代码
CREATE TABLE 表名(
	字段名 数据类型,
	...
	[CONSTRAINT] [外键名称] FOREIGN KEY (外键字段名) REFERENCES 主表 (主表列名)
);
sql 复制代码
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名)
REFERENCES 主表 (主表列名) ;

删除外键

sql 复制代码
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;

删除/更新行为

说明:添加了外键之后,再删除父表数据时产生的约束行为,我们就称为删除/更新行为。具体的删除/更新行为有以下几种:

语法:

sql 复制代码
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES
主表名 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE;
相关推荐
程序员岳焱2 小时前
Java 与 MySQL 性能优化:Java 实现百万数据分批次插入的最佳实践
后端·mysql·性能优化
计算机毕设定制辅导-无忧学长2 小时前
西门子 PLC 与 Modbus 集成:S7-1500 RTU/TCP 配置指南(一)
服务器·数据库·tcp/ip
程序员柳3 小时前
基于微信小程序的校园二手交易平台、微信小程序校园二手商城源代码+数据库+使用说明,layui+微信小程序+Spring Boot
数据库·微信小程序·layui
梦在深巷、3 小时前
MySQL/MariaDB数据库主从复制之基于二进制日志的方式
linux·数据库·mysql·mariadb
IT乌鸦坐飞机3 小时前
ansible部署数据库服务随机启动并创建用户和设置用户有完全权限
数据库·ansible·centos7
IT_10243 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle
Johny_Zhao4 小时前
Ubuntu系统安装部署Pandawiki智能知识库
linux·mysql·网络安全·信息安全·云计算·shell·yum源·系统运维·itsm·pandawiki
祁思妙想5 小时前
八股学习(三)---MySQL
数据库·学习·mysql
惊骇世俗王某人5 小时前
1.MySQL之如何定位慢查询
数据库·mysql
秦歌6666 小时前
向量数据库-Milvus快速入门
数据库·milvus