IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> mysql约束最清加最强解析 -> 正文阅读

[大数据]mysql约束最清加最强解析

目录

一.概述

1.约束概念:

2.分类:

二. 非空约束(not null,某一列的值不能为null)

1. 创建表时添加约束

2. 创建表完后,添加非空约束

3. 删除name的非空约束

三 . 唯一约束(unique,某一列的值不能重复)

1. 注意:

2. 在创建表时,添加唯一约束

3. 删除唯一约束

4. 在表创建完后,添加唯一约束

三 . 主键约束(primary key)

2. 在创建表时,添加主键约束

3. 删除主键

4. 创建完表后,添加主键

四. 自动增长

1. ?概念

2.建表并添加自动约束

3. 删除自动增长

4. 添加自动增长

五 . 外键约束(foreign key)

1.概念

2. 在创建表时,可以添加外键

3. 删除外键

4. 创建表之后,添加外键

六 .? 级联操作

1. 添加级联操作

2. 分类

3.总结:


一.概述

1.约束概念:

约束:对表中的数据进行限定,保证数据的正确性、有效性和完整性。

2.分类:

a. 主键约束:primary key

b. 非空约束:not null

c. 唯一约束:unique

d. 外键约束:foreign key

二. 非空约束(not null,某一列的值不能为null)

1. 创建表时添加约束

-- 创建一个名字不能为空值的学生表

?-- 创建一个名字不能为空值的学生表

CREATE TABLE student(

id INT,

NAME VARCHAR(10) NOT NULL -- name为非空

);

?

2. 创建表完后,添加非空约束

?
ALTER TABLE student MODIFY NAME VARCHAR(10) NOT NULL;

?

3. 删除name的非空约束

?
ALTER TABLE student MODIFY NAME VARCHAR(10);

?

三 . 唯一约束(unique,某一列的值不能重复)

1. 注意:

唯一约束可以有NULL值,但是只能有一条记录为null

2. 在创建表时,添加唯一约束

-- 创建一个电话号码不能重复的学生表

CREATE TABLE student(

id INT,

phone_number VARCHAR(11) UNIQUE -- 手机号

);

3. 删除唯一约束

ALTER TABLE student DROP INDEX phone_number;

4. 在表创建完后,添加唯一约束

ALTER TABLE student MODIFY phone_number VARCHAR(11) UNIQUE;

三 . 主键约束(primary key)

1. 注意:

a. 含义:非空且唯一

b. 一张表只能有一个字段为主键

c. 主键就是表中记录的唯一标识

2. 在创建表时,添加主键约束

?-- 创建一个id为主键的学生表

create table student(

id int primary key,-- 给id添加主键约束

name varchar(10)

);

?

3. 删除主键

ALTER TABLE student DROP PRIMARY KEY;

4. 创建完表后,添加主键

ALTER TABLE student MODIFY id INT PRIMARY KEY;

四. 自动增长

1. ?概念

自动增长:如果某一列是数值类型的,使用 auto_increment 可以来完成值得自动增长

2.建表并添加自动约束

-- 创建一张学生表,添加主键约束,并且完成主键自增长

create table student(

id int primary key auto_increment,-- 给id添加主键约束

name varchar(10)

);

3. 删除自动增长

ALTER TABLE student MODIFY id INT;

4. 添加自动增长

ALTER TABLE student MODIFY id INT AUTO_INCREMENT;

五 . 外键约束(foreign key)

1.概念

外键约束:让表于表产生关系,从而保证数据的正确性。

2. 在创建表时,可以添加外键

-- 语法:

create table 表名(

....

外键列

constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称)

);

3. 删除外键

ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;

4. 创建表之后,添加外键

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);

六 .? 级联操作

1. 添加级联操作

?
-- 语法:
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称)
 REFERENCES 主表名称(主表列名称) ON UPDATE CASCADE ON DELETE CASCADE ?;

?

2. 分类

a. 级联更新:ON UPDATE CASCADE

-- 语法:
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称)
 REFERENCES 主表名称(主表列名称) ON UPDATE CASCADE;

b. 级联删除:ON DELETE CASCADE

?-- 语法:
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) 
REFERENCES 主表名称(主表列名称)

?

3.总结:

联级操作的好处:方便对多表数据库进行统一操作,方便快捷

联级操作的弊端:会误删其他表相级联的全部数据和历史记录,在实际开发中对级联的操作要谨慎使用,思考清楚再使用。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-10-06 12:17:51  更:2021-10-06 12:19:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 1:23:10-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码