Mysql碎片整理:约束

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 约束:即一些关联规则

约束的概念

约束是指在修改表内容时遵循的某种规则。

主键

主键的作用:用来保证一列或一组列中的指是唯一的,主键设定后不再被改动。

主键可以用来唯一标识某一行的内容,通常用在WHERE语句中,搭配其它SQL语句。

三种方式定义主键

  1. 可视化界面(省略)
  2. 创建表的时候指定,关键字PRIMARY KEY
CREATE TABLE user
(
    user_id INTEGER NOT NULL PRIMARY KEY,
    name VARCHAR(25) NOT NULL
)
  1. 修改表结构时,指定主键
ALTER TABLE 表名 ADD PRIMARY KEY (列名);

外键

外键的作用:保证引用的完整性。它的好处通过一个例子可以理解:

  • A表是订单表(order_id,user_id),它有两个字段,第一个是主键,第二给是外键(属于B表的主键)
  • B表是用户表(user_id)

当订单产生的时候,如果没有外键关系,则A表中的user_id可能为空,但这明显不符合逻辑。所以在设计关系型数据库的时候,当两个表存在字段上的关联时,就应该设置外键。

其它好处还有:防止意外删除;或者级联删除

三种方式定义外键

  1. 可视化界面(省略)
  2. 创建表的时候指定,关键字REFERENCES
CREATE TABLE orders
(
    order_id INTEGER NOT NULL PRIMARY KEY,
    user_id INTEGER NOT NULL REFERENCES user(user_id)
)
  1. 修改表结构时,指定外键关系,指定A表中的外键。
ALTER TABLE A表名
ADD CONSTRAINT FOREIGN KEY(A表的字段) REFERENCES B表(B表的字段);

外键的删除规则

因为外键是两个表的关联,它对数据之间的依赖性又增强了,所以在删除数据的时候,如果有外键时,在删除的规则上就有讲究了。它需要再配合上ON关键字。

ALTER TABLE A表名
ADD CONSTRAINT FOREIGN KEY(A表的字段) REFERENCES B表(B表的字段)
ON DELETE xxx

这里xxx就是我们需要制定的规则,规则有:

父表表示原始的B表,而子表是定义外键的A表。
  1. CASCADE:从父表删除或更新且自动删除或更新子表中匹配的行。(删除(更新)B中的内容,A表内容自动被删除(更新))
  2. SET NULL:从父表删除或更新行,并设置子表中的外键列为NULL。使用该选项,必须保证子表列没有指定NOT NULL。(不常用)
  3. RESTRICT:拒绝对父表的删除或更新操作。
  4. NO ACTION:与RESTRICT相同(默认)。

这里常用的是1,3,4。而4是默认的。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
6月前
|
存储 安全 关系型数据库
MySQL数据库约束条件概述及其重要性讨论。
正确地实现并管理好各类紧缩条件将直接影响到企业信息管理水平与服务质量,在当今大数据背景下更显得格外重要;任何设计师都需要深刻理解其原理与运作机晰承担起责任使得所托管资料安全稳固同时又具备良好伸缩灵活度迎合日益复杂商务需求变动.
204 11
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
存储 关系型数据库 MySQL
MySQL数据库碎片化:隐患与解决策略
UUID作为主键可能导致MySQL存储碎片,影响性能。频繁的DML操作、字段长度变化和非顺序插入(如UUID)都会造成碎片。碎片增加磁盘I/O,降低查询效率,浪费空间,影响备份速度。建议使用自增ID,固定长度字段,并适时运行OPTIMIZE TABLE来减少碎片。
|
关系型数据库 MySQL
MYSQL-多表操作-外键约束
MYSQL-多表操作-外键约束
|
关系型数据库 MySQL
MYSQL:约束(主键约束)
MYSQL:约束(主键约束)
|
存储 SQL 关系型数据库
【MySQL基础篇】MySQL约束语法
文章介绍了MySQL中表的约束概念,包括非空、唯一、主键、默认和外键约束,以及如何在创建和修改表时指定这些约束。外键约束用于保持数据的一致性和完整性,文章通过示例展示了添加、删除外键的语法,并讨论了不同的删除/更新行为,如CASCADE和SETNULL。
【MySQL基础篇】MySQL约束语法
|
SQL 存储 关系型数据库
MySQL 回收表碎片实践教程
在 MySQL 数据库中,随着数据的增删改操作,表空间可能会出现碎片化,这不仅会占用额外的存储空间,还可能降低表的扫描效率,特别是一些大表,在进行数据清理后会产生大量的碎片。本篇文章我们一起来学习下如何进行碎片回收以及相关注意点。
453 1
MySQL 回收表碎片实践教程
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
198 1
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
存储 关系型数据库 MySQL
MySQL(条件约束)
为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销

推荐镜像

更多