MySQL 2:MySQL约束
一、定义
约束(constraint),即表中数据的限制条件。在表设计中加入约束的目的是保证表中记录的完整性和有效性。 比如user表,有些列(手机号)的值不能为空,有些列(身份证号)的值不能重复。
主要分为主键约束(primary key,PK)、自增长约束(auto_increment)、非空约束(not null)、唯一性约束(unique)、默认约束(default)、零填充约束(zerofill)、外键约束(foreign key,FK)。
二、主键约束
MySQL的主键约束是一列或多列的组合,其值可以唯一标识表中的每一行,便于尽快在RDBMS中找到一行。主键约束相当于唯一约束+非空约束的组合。主键约束列不允许重复,也不允许空值。每个表最多允许一个主键。主键约束的关键字是:primary key。创建主键约束时,系统默认会在列和列组合上创建对应的唯一索引。
操作:添加单列主键、添加多列主键(联合主键)、删除主键。
1. 添加单列主键
创建单列主键有两种方式,一种是定义字段时指定主键,另一种是定义字段后指定主键。
定义字段时指定主键:
-- 在 create table 语句中,通过 PRIMARY KEY 关键字来指定主键。
-- 在定义字段的同时指定主键,语法格式如下:
create table 表名(...<字段名> <数据类型> primary key ...
)
例如:
create table emp1(eid int primay key,name VARCHAR(20),deptId int,salary double
);
定义字段后指定主键:
--在定义字段之后再指定主键,语法格式如下:
create table 表名(...[constraint <约束名>] primary key [字段名]
);
例如:
create table emp2(eid INT,name VARCHAR(20),deptId INT,salary double,constraint pk1 primary key(id));
2. 添加多列主键(联合主键)
联合主键就是主键由表中的多个字段组成。当主键由多个字段组成时,不能直接在字段名后声明主键约束。一张表只能有一个主键,联合主键也是一个主键。
create table 表名(...primary key (字段1,字段2,…,字段n)
);
例如:
create table emp3( name varchar(20), deptId int, salary double, primary key(name,deptId)
);
3. 通过修改表结构添加主键
主键约束不仅可以在建表时创建,也可以在修改表时添加。
create table 表名(...
);
alter table <表名> add primary key(字段列表);
例如:
-- 添加单列主键
create table emp4(eid int, name varchar(20), deptId int, salary double
);
alter table emp4 add primary key(eid);
4. 删除主键约束
当表中不再需要主键约束时,需要将其从表中删除。有一种比创建主键约束更简单的方法来删除主键约束。
alter table <数据表名> drop primary key;
例如:
-- 删除单列主键
alter table emp1 drop primary key;-- 删除联合主键
alter table emp5 drop primary key;
三、自增长约束
自增长(auto increment)约束指在MySQL中,当主键定义为自增长时,主键的值不再需要用户输入数据,而是由数据库系统根据定义自动赋值。每增加一条记录,主键会自动以相同的步长增长。可以通过给字段增加属性实现主键自增长。
字段名 数据类型 auto_increment
例如:
create table t_user1( id int primary key auto_increment, name varchar(20)
);
默认情况下,auto_increment 的初始值为 1,每增加一条新记录,字段值自动增加 1。一张表中只有一个字段可以使用auto_increment约束,并且该字段必须有唯一索引以避免序号重复(即主键或部分主键)。受 auto_increment 约束的字段必须具有 NOT NULL 属性。auto_increment约束的字段只能是整型(TINYINT、SMALLINT、INT、BIGINT等)。auto_increment 约束字段的最大值受字段数据类型的约束。 如果达到上限,auto_increment 将失败。
1. 指定自增字段初始值
如果在第一条记录中设置了该字段的初始值,则新添加的记录将从该初始值开始递增。 例如,如果表中插入的第一条记录的id值设置为5,那么在插入记录时,id值将从5开始增加。
-- 方式1,创建表时指定
create table t_user2 ( id int primary key auto_increment, name varchar(20)
)auto_increment=100;-- 方式2,创建表之后指定
create table t_user3 ( id int primary key auto_increment, name varchar(20)
);alter table t_user2 auto_increment=100;
2. delete和truncate在删除后自增列的变化
delete数据后,从断点开始自动增长。truncate数据后自动增长,从默认起始值开始。
四、非空约束
非空约束(not null)是指一个字段的值不能为空。对于使用非空约束的字段,如果用户在添加数据时没有指定值,数据库系统会报错。
--方式1:
<字段名><数据类型> not null;
--方式2:
alter table 表名 modify 字段 类型 not null;
例如:
-- 方式1,创建表时指定
create table t_user6 ( id int , name varchar(20) not null, address varchar(20) not null
);
-- 方式1,创建表后指定
create table t_user7 ( id int , name varchar(20) , -- 指定非空约束 address varchar(20) -- 指定非空约束
);
alter table t_user7 modify name varchar(20) not null;
alter table t_user7 modify address varchar(20) not null;
1. 删除非空约束
alter table 表名 modify 字段 类型
例如:
alter table t_user7 modify name varchar(20);
alter table t_user7 modify address varchar(20);
五、唯一约束
唯一约束(Unique Key)是指该字段的值在所有记录中都不能重复。比如,给id字段加上唯一约束后,每条记录的id值都是唯一的,不能重复。
--方式1:
<字段名> <数据类型> unique
--方式2:
alter table 表名 add constraint 约束名 unique(列);
例如:
-- 创建表时指定
create table t_user8 ( id int , name varchar(20) , phone_number varchar(20) unique -- 指定唯一约束
);
-- 创建表后指定
create table t_user9 ( id int , name varchar(20) , phone_number varchar(20) -- 指定唯一约束
);
alter table t_user9 add constraint unique_ph unique(phone_number);
1. 删除唯一约束
alter table <表名> drop index <唯一约束名>;
例如:
alter table t_user9 drop index unique_ph;
六、默认约束
默认约束用于指定列的默认值。
--方式1:
<字段名> <数据类型> default <默认值>;
--方式2:
alter table 表名 modify 列名 类型 default 默认值;
例如:
create table t_user10 ( id int, name varchar(20), address varchar(20) default '北京' -- 指定默认约束
);create table t_user11 ( id int, name varchar(20), address varchar(20)
);
alter table t_user11 modify address varchar(20) default '北京';
1. 删除默认约束
alter table <表名> modify column <字段名> <类型> default null;
例如:
alter table t_user11 modify column address varchar(20) default null;
七、零填充约束
零填充约束(zerofill)指插入数据时,当字段的值长度小于定义的长度时,会在该值前面加上相应的0。zerofill 默认为 int(10)。使用zerofill时,默认会自动加上Unsigned(无符号)属性。使用无符号属性后,取值范围是原来的两倍。例如有符号为-128~+127,无符号为0~256。
例如:设置id字段的长度为8,则真实数据为8,显示在数据库中为00008。
create table t_user12 ( id int zerofill, -- 零填充约束name varchar(20)
);
1. 删除零填充约束
alter table t_user12 modify id int;
相关文章:
MySQL 2:MySQL约束
一、定义 约束(constraint),即表中数据的限制条件。在表设计中加入约束的目的是保证表中记录的完整性和有效性。 比如user表,有些列(手机号)的值不能为空,有些列(身份证号ÿ…...
C4--Vivado添加列表中不存在的FLash器件2023-02-10
以华邦SPI FLASH W25Q128JVEIQ为例进行说明。(其他Flash添加步骤一致) 1.本地vivado安装目录D:\Softwares\xlinx_tools\Vivado\2020.2\data\xicom下,找到xicom_cfgmem_part_table.csv文件,这个表与vivado hardware manager中的器…...
php代码审计
准备工作 了解CMS的基本信息 该CMS使用的是什么设计模式?该CMS每个目录大概负责的功能(视图、缓存、控制器等)。该CMS处理请求的基本流程是如何走的?以及在系统中使用的全局过滤函数是如何对数据进行处理的? 代码审计方法 敏感函数回溯 …...
接口测试入门,如何划分接口文档
1.首先最主要的就是要分析接口测试文档,每一个公司的测试文档都是不一样的。具体的就要根据自己公司的接口而定,里面缺少的内容自己需要与开发进行确认。 我认为一针对于测试而言的主要的接口测试文档应该包含的内容分为以下几个方面。 a.具体的一个业…...
数据库学习第二天
第7章 系统预定义函数 函数:代表一个独立的可复用的功能。 和Java中的方法有所不同,不同点在于:MySQL中的函数必须有返回值,参数可以有可以没有。 MySQL中函数分为: (1)系统预定义函数&…...
NODE => CORS跨域资源共享学习
1.CORS跨域资源共享 cors是Express的一个第三方中间件。通过安装和配置cors中间件,可以很方便地解决跨域问题 运行npm install cors 安装中间件使用const cors require(‘cors’) 导入中间件在路由之前调用 app.use(cors()&#…...
golang rabbitMQ 生产者复用channel以及生产者组分发策略
引用的是rabbitMQ官方示例的库:github.com/rabbitmq/amqp091-go在网络编程中我们知道tcp连接的创建、交互、销毁等相关操作的"代价"都是很高的,所以就要去实现如何复用这些连接,并要做到高效并可靠。预期效果:项目初始化…...
掌握了这项技能的性能测试师,90%都升职加薪了
初入职场的新人该怎么做才能让自己快速成长?在公司一直做着手工测试,如何才能提升自己,避免陷入“只涨年龄不涨经验”的尴尬?做为一名软件测试工程师,我们不得不去面对这些问题,有的人找到了答案࿰…...
linux中crontab定时任务导致磁盘满和云监控未报警的的坑
一个后台开发者,兼职运维工作中,配置linux中crontab定时任务,导致磁盘满和云监控未报警的问题的坑。 1.磁盘满 使用命令 df -h2.问题排查 2.1排查日志 命令 cat /var/log/messages日志文件的默认路径是:/var/log 下面是几个…...
vscode中安装python运行调试环境
在运行代码之前,需要到微软商店下载安装python环境,35m,都是自动的。 1、安装python 的extensions插件。 ctrlshiftx 输入 python 后点击 install 按钮。 2、新建文件夹spider文件夹。 3、在新建文件夹spider下新建文件spider.py源代码。…...
【微服务】微服务架构超强讲解,通俗易懂
微服务架构目录一、微服务架构介绍二、出现和发展三、传统开发模式和微服务的区别四、微服务的具体特征五、面向服务的架构SOA(service oriented architecture)和微服务的区别1、SOA喜欢重用,微服务喜欢重写2、SOA喜欢水平服务,微…...
内核中的竞态产生的原因和解决方法
产生原因: 由于多进程对临界资源的抢占 根本原因: 1、对于单核处理器而言,内核支持抢占就会出现竞态 2、对于多核处理器而言,是核与核的竞态 3、进程与中断间存在竞态 4、arm开发板不会出现中断与中断间的竞态(目前&am…...
【微服务】Elasticsearch文档索引库操作(二)
🚗Es学习第二站~ 🚩Es学习起始站:【微服务】Elasticsearch概述&环境搭建(一) 🚩本文已收录至专栏:微服务探索之旅 👍希望您能有所收获 一.索引库操作 索引库就类似数据库表,mapping映射就类…...
【论文速递】NAACL2022-DEGREE: 一种基于生成的数据高效事件抽取模型
【论文速递】NAACL2022-DEGREE: 一种基于生成的数据高效事件抽取模型 【论文原文】:DEGREE A Data-Efficient Generation-Based Event Extraction Mode 【作者信息】:I-Hung Hsu , Kuan-Hao Huang, Elizabeth Boschee ÿ…...
C++类和对象(下)
✨个人主页: Yohifo 🎉所属专栏: C修行之路 🎊每篇一句: 图片来源 I do not believe in taking the right decision. I take a decision and make it right. 我不相信什么正确的决定。我都是先做决定,然后把…...
Java常见的六种线程池、线程池-四种拒绝策略总结
点个关注,必回关 一、线程池的四种拒绝策略: CallerRunsPolicy - 当触发拒绝策略,只要线程池没有关闭的话,则使用调用线程直接运行任务。 一般并发比较小,性能要求不高,不允许失败。 但是,由于…...
Node=>Express中间件分类 学习4
1.中间件分类 应用级别的中间件路由级别的中间件错误级别的中间件Express 内置的中间件第三方的中间件 通过app.use()或app.get()或app.post()绑定到app实力上的中间件,叫做应用级别的中间件 …...
在阿里当外包,是一种什么工作体验?
上周和在阿里做外包的朋友一起吃饭,朋友吃着吃着,就开启了吐槽模式。 他一边喝酒一边说,自己现在做着这份工作,实在看不到前途。 看他状态不佳,问了才知道,是手上的项目太磨人。 他们现在做的项目&#…...
Vue3快速入门【二】
Vue3快速入门一、传值父传子,子传父v-model二、插槽2.1、匿名插槽2.2、具名插槽2.3、插槽作用域2.4、插槽作用域案例2.4.1、初始布局2.4.2、插槽使用2.4.3、点击编辑按钮获取本行数据(插槽作用域的使用)2.4.4、类型书写优化2.4.5、全局接口抽…...
C++-类和对象(上)
类和对象(上)一,构造函数1,概念2,特性二,析构函数1,概念2,特性三,拷贝构造1,概念2,特性四,运算符重载1,概念2,…...
CVPR 2025 MIMO: 支持视觉指代和像素grounding 的医学视觉语言模型
CVPR 2025 | MIMO:支持视觉指代和像素对齐的医学视觉语言模型 论文信息 标题:MIMO: A medical vision language model with visual referring multimodal input and pixel grounding multimodal output作者:Yanyuan Chen, Dexuan Xu, Yu Hu…...
简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...
Java 加密常用的各种算法及其选择
在数字化时代,数据安全至关重要,Java 作为广泛应用的编程语言,提供了丰富的加密算法来保障数据的保密性、完整性和真实性。了解这些常用加密算法及其适用场景,有助于开发者在不同的业务需求中做出正确的选择。 一、对称加密算法…...
【python异步多线程】异步多线程爬虫代码示例
claude生成的python多线程、异步代码示例,模拟20个网页的爬取,每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程:允许程序同时执行多个任务,提高IO密集型任务(如网络请求)的效率…...
高防服务器能够抵御哪些网络攻击呢?
高防服务器作为一种有着高度防御能力的服务器,可以帮助网站应对分布式拒绝服务攻击,有效识别和清理一些恶意的网络流量,为用户提供安全且稳定的网络环境,那么,高防服务器一般都可以抵御哪些网络攻击呢?下面…...
LLMs 系列实操科普(1)
写在前面: 本期内容我们继续 Andrej Karpathy 的《How I use LLMs》讲座内容,原视频时长 ~130 分钟,以实操演示主流的一些 LLMs 的使用,由于涉及到实操,实际上并不适合以文字整理,但还是决定尽量整理一份笔…...
华为OD机考-机房布局
import java.util.*;public class DemoTest5 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseSystem.out.println(solve(in.nextLine()));}}priv…...
解决:Android studio 编译后报错\app\src\main\cpp\CMakeLists.txt‘ to exist
现象: android studio报错: [CXX1409] D:\GitLab\xxxxx\app.cxx\Debug\3f3w4y1i\arm64-v8a\android_gradle_build.json : expected buildFiles file ‘D:\GitLab\xxxxx\app\src\main\cpp\CMakeLists.txt’ to exist 解决: 不要动CMakeLists.…...
MacOS下Homebrew国内镜像加速指南(2025最新国内镜像加速)
macos brew国内镜像加速方法 brew install 加速formula.jws.json下载慢加速 🍺 最新版brew安装慢到怀疑人生?别怕,教你轻松起飞! 最近Homebrew更新至最新版,每次执行 brew 命令时都会自动从官方地址 https://formulae.…...
