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,…...
基于大模型的 UI 自动化系统
基于大模型的 UI 自动化系统 下面是一个完整的 Python 系统,利用大模型实现智能 UI 自动化,结合计算机视觉和自然语言处理技术,实现"看屏操作"的能力。 系统架构设计 #mermaid-svg-2gn2GRvh5WCP2ktF {font-family:"trebuchet ms",verdana,arial,sans-…...
前端倒计时误差!
提示:记录工作中遇到的需求及解决办法 文章目录 前言一、误差从何而来?二、五大解决方案1. 动态校准法(基础版)2. Web Worker 计时3. 服务器时间同步4. Performance API 高精度计时5. 页面可见性API优化三、生产环境最佳实践四、终极解决方案架构前言 前几天听说公司某个项…...
遍历 Map 类型集合的方法汇总
1 方法一 先用方法 keySet() 获取集合中的所有键。再通过 gey(key) 方法用对应键获取值 import java.util.HashMap; import java.util.Set;public class Test {public static void main(String[] args) {HashMap hashMap new HashMap();hashMap.put("语文",99);has…...
线程同步:确保多线程程序的安全与高效!
全文目录: 开篇语前序前言第一部分:线程同步的概念与问题1.1 线程同步的概念1.2 线程同步的问题1.3 线程同步的解决方案 第二部分:synchronized关键字的使用2.1 使用 synchronized修饰方法2.2 使用 synchronized修饰代码块 第三部分ÿ…...
【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)
服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...
linux 错误码总结
1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...
uniapp中使用aixos 报错
问题: 在uniapp中使用aixos,运行后报如下错误: AxiosError: There is no suitable adapter to dispatch the request since : - adapter xhr is not supported by the environment - adapter http is not available in the build 解决方案&…...
如何在网页里填写 PDF 表格?
有时候,你可能希望用户能在你的网站上填写 PDF 表单。然而,这件事并不简单,因为 PDF 并不是一种原生的网页格式。虽然浏览器可以显示 PDF 文件,但原生并不支持编辑或填写它们。更糟的是,如果你想收集表单数据ÿ…...
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数 在软件开发中,单例模式(Singleton Pattern)是一种常见的设计模式,确保一个类仅有一个实例,并提供一个全局访问点。在多线程环境下,实现单例模式时需要注意线程安全问题,以防止多个线程同时创建实例,导致…...
JVM 内存结构 详解
内存结构 运行时数据区: Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器: 线程私有,程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 每个线程都有一个程序计数…...
