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,…...
uniapp 对接腾讯云IM群组成员管理(增删改查)
UniApp 实战:腾讯云IM群组成员管理(增删改查) 一、前言 在社交类App开发中,群组成员管理是核心功能之一。本文将基于UniApp框架,结合腾讯云IM SDK,详细讲解如何实现群组成员的增删改查全流程。 权限校验…...
(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)
题目:3442. 奇偶频次间的最大差值 I 思路 :哈希,时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况,哈希表这里用数组即可实现。 C版本: class Solution { public:int maxDifference(string s) {int a[26]…...
设计模式和设计原则回顾
设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...
iOS 26 携众系统重磅更新,但“苹果智能”仍与国行无缘
美国西海岸的夏天,再次被苹果点燃。一年一度的全球开发者大会 WWDC25 如期而至,这不仅是开发者的盛宴,更是全球数亿苹果用户翘首以盼的科技春晚。今年,苹果依旧为我们带来了全家桶式的系统更新,包括 iOS 26、iPadOS 26…...
stm32G473的flash模式是单bank还是双bank?
今天突然有人stm32G473的flash模式是单bank还是双bank?由于时间太久,我真忘记了。搜搜发现,还真有人和我一样。见下面的链接:https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...
自然语言处理——Transformer
自然语言处理——Transformer 自注意力机制多头注意力机制Transformer 虽然循环神经网络可以对具有序列特性的数据非常有效,它能挖掘数据中的时序信息以及语义信息,但是它有一个很大的缺陷——很难并行化。 我们可以考虑用CNN来替代RNN,但是…...
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别 直接训练提示词嵌入向量的核心区别 您提到的代码: prompt_embedding = initial_embedding.clone().requires_grad_(True) optimizer = torch.optim.Adam([prompt_embedding...
sipsak:SIP瑞士军刀!全参数详细教程!Kali Linux教程!
简介 sipsak 是一个面向会话初始协议 (SIP) 应用程序开发人员和管理员的小型命令行工具。它可以用于对 SIP 应用程序和设备进行一些简单的测试。 sipsak 是一款 SIP 压力和诊断实用程序。它通过 sip-uri 向服务器发送 SIP 请求,并检查收到的响应。它以以下模式之一…...
[大语言模型]在个人电脑上部署ollama 并进行管理,最后配置AI程序开发助手.
ollama官网: 下载 https://ollama.com/ 安装 查看可以使用的模型 https://ollama.com/search 例如 https://ollama.com/library/deepseek-r1/tags # deepseek-r1:7bollama pull deepseek-r1:7b改token数量为409622 16384 ollama命令说明 ollama serve #:…...
根目录0xa0属性对应的Ntfs!_SCB中的FileObject是什么时候被建立的----NTFS源代码分析--重要
根目录0xa0属性对应的Ntfs!_SCB中的FileObject是什么时候被建立的 第一部分: 0: kd> g Breakpoint 9 hit Ntfs!ReadIndexBuffer: f7173886 55 push ebp 0: kd> kc # 00 Ntfs!ReadIndexBuffer 01 Ntfs!FindFirstIndexEntry 02 Ntfs!NtfsUpda…...
