mysql快速精通(二)约束和策略

主打一个实用

本篇主要是应用,具体sql操作语句自查

一. 主键约束

主键用于唯一标识一条记录,每个表只能有一个主键(多字段为联合主键)

主键列特性:非空唯一

  1. Navicat中添加主键

新建表时如果没有设主键是会失败的,这个金色钥匙就是主键的标识了

  1. 主键自增策略

选中主键加上即可,自增策略可以按顺序自动生成不重复序号

  1. 截断表

截断表truncate与清空表delete的区别🎈

截断表:保留表结构,其他都删除,自增字段会回到默认值开始

清空表:保留表结构,不释放空间,自增字段不会重置

二. 非空约束

添加非空约束

三.唯一约束

添加唯一约束

四. 缺省(默认)约束

即默认值,如果未填会默认该值

五. 外键约束

  1. 单表的缺点

数据内容大部分重复,并且修改时需要遍历所有内容修改,比如所在社区,可以将社区单独划为一张表,在原表只需记录其id

  1. 外键的规范

要求:外键列的数据类型和长度必须和被参照的主键列的数据类型和长度一致

  1. 外键的添加方式

关联键为主键的是主表,反之,从表(子表)

外键在从表添加

此处以级联更新删除为例,当然不止这一种选项

  1. 更新删除策略

CASCADE:从父表删除或更新且自动删除或更新子表中匹配的行
SET NULL:从父表删除或更新行,并设置子表中的外键列为NULL。如果使用该选项,必须保证子表列没有指定NOT NULL
RESTRICT:拒绝对父表的删除或更新操作
NO ACTION:标准SQL的关键字,在MySQL中与RESTRICT相同

相关推荐
g***72702 小时前
从MySQL迁移到PostgreSQL的完整指南
数据库·mysql·postgresql
IT教程资源D2 小时前
[N_129]基于springboot,vue学生宿舍管理系统
mysql·vue·前后端分离·springboot宿舍·宿舍管理系统
冷雨夜中漫步2 小时前
Maven BOM(Bill of Materials)使用指南与常见错误
java·数据库·maven
hanyi_qwe2 小时前
Mysql主从复制与读写分离测试
数据库·mysql
梁bk2 小时前
Redis 通信协议(RESP)
数据库·redis·缓存
思成不止于此2 小时前
MySQL 约束详解:保证数据完整性的核心机制
数据库·笔记·学习·mysql
伐尘3 小时前
【MySQL】windows系统下mysql慢日志查询
windows·mysql·adb
理想三旬3 小时前
数据定义:模式、表、索引
数据库
c***87193 小时前
讲解进阶之路:模块、包和异常处理-上篇
数据库·redis·哈希算法
!chen3 小时前
Oracle分区表+本地索引 核心优化方案
数据库·oracle