MySQL——数据的删除以及MySQL中的约束

news2024/9/22 7:26:30

删除数据

删除表中的一行数据,也必须加上 WHERE条件,否则整列的数据都会被删除。删除语句:

delete from 表名 where 条件;

他会将所有的符合条件的数据删除,如果不写条件,则表中的数据全部删除:

如果不添加where:

首先我们的工具会提醒我们这个语句非常的危险,这是工具自带的功能,如果你使用的是黑窗口则不会有这种提示,我们无视风险,继续执行:

那么表中的数据就全部都被删除了。

我们再找一个有数据的表:

那么我们使用另一个语句也可以删除数据:

命令格式是这样的:

truncate table 表名;

演示一下:

truncate与delete的区别在之后详细的介绍的时候会说到,现在只需要记住这个语句也可以做到删除数据的效果就可以了。

约束是什么

约束是一种限制,它通过对表的行或列的数据做出限制,来确保表的数据的完整性、唯一性。本节实验将在实践操作中熟悉 MySQL中的几种约束。

SQL中最常用的 SELECT语句,用来在表中选取数据,本节实验中将通过一系列的动手操作详细学习SELECT语句的用法。

. SQL约束

. SELECT基本语法

·数学符号条件

·AND OR IN

·通配符

·排序

. SQL内置函数和计算

·子查询与连接查询

SQL约束分类

听名字就知道,约束是一种限制,它通过对表的行或列的数据做出限制,来确保表的数据的完整性、唯一性。

比如,规定一个用户的用户名不能为空值且没有重复的记录,这就是一种约束规则。

在MySQL中,通常有这几种约束:

约束类型

主键

默认值

唯一

外键

非空

关键字

PRIMARY KEY

DEFAULT

UNIQUE

FOREIGN KEY

NOT NULL

建立含有约束的表

在之前我们介绍创建表的格式的时候,添加约束的地方是在字段类型的后面,我们直接添加对应的约束即可:

create table if not exists book( id int primary key , name varchar(20) unique , age varchar(3) not null , address varchar(20) default '背景' );

我们创建了一个表,这个表中的每一列都带有一个约束,从上到下分别是主键约束,唯一约束,非空约束,默认约束,我们接下来会分别介绍这集中约束的作用。

主键

在数据库中,如果有两行记录数据完全一样,那么如何来区分呢?答案是无法区分,如果有两行记录完全相同,那么对于MySQL就会认定它们是同一个实体,这于现实生活是存在差别的。

假如我们要存储一个学生的信息,信息包含姓名,身高,性别,年龄。

不幸的是有两个女孩都叫小梦,且她们的身高和年龄相同,数据库将无法区分这两个实体,这时就需要用到主键了。

主键(PRIMARY KEY)是用于约束表中的一行,作为这一行的唯一标识符,在一张表中通过主键就能准确定位到一行,因此主键十分重要,主键不能有重复记录且不能为空。

我们向表中插入一行数据:

我们表中的id这一列已经添加了主键约束,那么按照主键约束的规则,不能重复且不能为空,如果我们再次填写一个id的值和他一样则会出错:

当我们插入同样的id时,由于id字段有主键约束,则会报错,报错信息是重复的主键的值。

并且当我们不填充数据的数据也会报错:

报错信息是不能为空,是因为我们添加了主键约束才会报这个错。

联合主键

在有些时候,单一的主键并不能满足于使用,那么就需要使用多个列组成联合主键,联合主键的生命格式如下:

create table if not exists book1( id int , u_id int, name varchar(20) unique , age varchar(3) not null , address varchar(20) default '北京', primary key (id,u_id) );

联合主键的定义就不能在字段后面定义,需要在建表语句的最后使用primary key ()关键字定义,括号内的参数就是要组成联合主键的字段名,多个字段名之间用逗号隔开。

主键自增

主键的值是固定的,有时候我们在自己添加的时候可能会忘记自己添加到那里了,或者如果中间有空行就会出错,不如直接让主键列自己增长,我们不用手动填入主键的值,就可以在表中自己填入正确的主键值:

在主键列的主键关键字primary key后面使用另一个关键字auto_increment,就可以在添加主键的时候填入一个null,之后就可以在表中自己填入对应的值:

可以看到,我们在插入数据的时候填入的是null,但是我们在数据库中显示的数字是按照1,2,3……这样自动增长的,这就是主键自增。

默认值约束

默认值约束(DEFAULT)规定,当有DEFAULT约束的列,插入数据为空时,将使用默认值。

默认值常用于—些可有可无的字段,比如用户的个性签名,如果用户没有设置,系统给他应该设定一个默认的文本,比如空文本或‘这个人太懒了,没有留下任何信息'

在之前的案例中,第四个字段使用的就是默认值约束:

当这个字段我们不填充任何的值的时候,那么default后面的值就会被自动填充进去:

注意,是不填充任何的值,如果你最后写了一个null,那么最后的显示结果是这样的:

可以看到默认值约束并没有应用上去,这里涉及到一个MySQL的null值和空值的区别,其实这个null也是一种数值,这个在之后我们会深入讨论他的问题。

这里我们只需要知道,如果要default约束被应用只需要填充的时候使用选择列填充的方式,不填充任何内容在自动约束所在的列中即可。

唯一约束

唯—约束(UNIQUE)比较简单,它规定—张表中指定的一列的值必须不能有重复值,即这一列每个值都是唯一的。

我们之间案例中的第二个字段就添加了非空约束,我们先看一下表中已有的数据:

当前表中的name的值是添加了唯一约束的,并且此时没有重复的值,那么现在我添加一个重复的值:

当添加了唯一约束的字段中添加了重复的值,那么就会报错,报错信息是重复的键值,在book2表的name字段上。

那么如果是两个null值的话,会怎么样呢?

null并不算做是重复的值,现在理解比较好理解,就是没有值也就没有比较的对象嘛,但是之后我们介绍null的细节的时候,我们再详细的展开null到底代表的是什么。

外键约束

外键(FOREIGN KEY)既能确保数据完整性,也能表现表之间的关系。

比如,现在有用户表和文章表,给文章表中添加一个指向用户id 的外键,表示这篇文章所属的用户id,外键将确保这个外键指向的记录是存在的,如果你尝试删除一个用户,而这个用户还有文章存在于数据库中,那么操作将无法完成并报错。因为你删除了该用户过后,他发布的文章都没有所属用户了,而这样的情况是不被允许的。同理,你在创建一篇文章的时候也不能为它指定一个不存在的用户id。

一个表可以有多个外键,每个外键必须REFERENCES(参考)另—个表的主键,被外键约束的列,取值必须在它参考的列中有对应值。

外键约束是什么呢,就是我现在有一个表,我的表中的某一个列添加了外键约束,这个外键约束参考了另一个表中的主键列,那么我在向添加了外键约束的字段中插入值的时候,这个值的取值范围只能是另一个表中主键列已经存在的值,否则会插入失败。类似于ENUM,只能从一个范围中取值,只不过这个范围在另一个表上。

现在我创建了两张表,一张student,一张stu_cord,现在stu_cord表的c_id添加了外键约束,在插入数据的时候,stu_cord的c_id的值只能插入student表中的id字段已有的值:

我先给student插入一些数据,然后向stu_cord中插入一些数据:

现在是一切正常,但是如果我这么操作:

插入失败了,为什么呢?就是因为当我向c_id列中插入数据的时候,c_id列添加了外键约束,这个列中插入的数值要参考student的id字段的值,只能插入id字段中已有的值,现在student表中的数值是这样的:

很显然,我要插入的4并不在他的id中,所以我插入失败了,这就是外键约束的一个体现,当你插入的数值不在我参考的列中,那么你的值无法插入。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/986981.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

软件测试/测试开发丨学会与 AI 对话,高效提升学习效率

点此获取更多相关资料 简介 ChatGPT 的主要优点之一是它能够理解和响应自然语言输入。在日常生活中,沟通本来就是很重要的一门课程,沟通的过程中表达越清晰,给到的信息越多,那么沟通就越顺畅。 和 ChatGPT 沟通也是同样的道理&…

方向介绍:基于深度学习的轨迹预测

方向介绍:基于深度学习的轨迹预测 文章目录 方向介绍:基于深度学习的轨迹预测问题定义典型方法挑战未来展望参考 基于深度学习的轨迹预测是一种利用神经网络模型来预测移动物体的未来位置和运动状态的技术。这种技术在许多领域都有重要的应用&#xff0c…

Jetpack Compose 入门教程之Text

这个文本显示组件应该是我们最常用的组件,下面会非常细 归纳 实例 下面一一演示这些属性与控制逻辑 文本的展示 Text组件 所有构造方法都是text:String,要想用string.xml里面的字符串资源 得使用 stringResource方法,其相似方法如下/** Copyright 2019 The Android Open Sou…

如何挑选低值易耗品管理系统?优化企业管理效率与成本控制

在现代企业管理中,低值易耗品的管理是一个容易被忽视但却十分重要的环节。低值易耗品包括办公用品、耗材、工具等,它们虽然单价不高,但数量庞大且频繁使用,对企业的日常运营和成本控制有着重要影响。为了提高管理效率、降低成本&a…

Linux与shell命令行学习

文章目录 走进shell基本的bash shell命令2.1 遍历目录 cd2.2 查看文件和目录列表 ls2.3 创建文件 touch2.4 复制文件 cp2.5 自动补全 tab2.6 链接文件 ln2.7 文件重命名 mv2.8 删除文件 rm2.9 创建目录 mkdir2.10 删除目录 rmdir2.11 查看文件类型 file2.12 查看整个文件 cat、…

flume1.11.0安装部署

1、准备安装包apache-flume-1.11.0-bin.tar.gz; 上传; 2、安装flume-1.11.0; 解压; tar -zxvf apache-flume-1.11.0-bin.tar.gz -C /opt/server 进入conf目录,修改flume-env.sh,配置JAVA_HOME&#xff1b…

docker 生成镜像的几个问题

docker 生成镜像的几个问题 根据jdk8.tar.gz 打包Jdk8 镜像失败运行镜像报错差不多是网络ip错误,在网上说重启docker即可解决运行mysql5.7.25 镜像失败向daemon.json文件添加内容导致docker重启失败docker run 命令常用参数根据jdk8.tar.gz 打包Jdk8 镜像失败 首选做准备工作…

有向图和无向图的表示方式(邻接矩阵,邻接表)

目录 一.邻接矩阵 1.无向图​编辑 2.有向图 补充:网(有权图)的邻接矩阵表示法 二.邻接表 1.无向图 2.有向图 三.邻接矩阵与邻接表的关系 一.邻接矩阵 1.无向图 (1)对角线上是每一个顶点与自身之间的关系&…

智慧能源方案:TSINGSEE青犀AI算法中台在能源行业的应用

一、方案背景 互联网、物联网、人工智能等新一代信息技术引领新一轮产业革命,加快能源革命步伐。尤其是随着人工智能技术的不断发展,AI智能检测与识别技术在能源行业的应用也越来越广泛。与此同时,国家出台多项政策,将智慧能源纳…

【HTML5高级第三篇】drag拖拽、音频视频、defer/async属性、dialog应用

文章目录 一、拖拽事件1.1 拖拽事件1.2 案例:拖拽丢弃图片 二、音频和视频三、defer 与 async 属性3.1 概述3.2 示例一:3.3 示例二: 四、dialog 元素 一、拖拽事件 原生JavaScipt案例合集 JavaScript DOM基础 JavaScript 基础到高级 Canvas…

LabVIEW利用局部放电分析高压电气设备状态诊断

LabVIEW利用局部放电分析高压电气设备状态诊断 目前,高压电气设备状态的监控系统解决了早期故障检测的问题。局部放电起源于电力电气装置的绝缘。局部放电会导致绝缘层逐渐磨损和加速老化,因此可能导致绝缘完全击穿。因此,局部放电检测及其特…

gitLab(git)误提交命令

1.先使用下面命令查看一下分支上已提交的信息 git log 2.回退到之前的版本 git reset —hard 你要删除的提交哈希码(一般是离这个命令最近的一串数字) 3.覆盖掉远端的版本信息,使远端的仓库也回退到相应的版本 注意:切换到你提…

安装K8s基础环境软件(二)

所有节点执行 1、安装docker sudo yum install -y yum-utils sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.reposudo yum install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin systemctl…

解决报错之org.aspectj.lang不存在

一、IDEA在使用时,可能会遇到maven依赖包明明存在,但是build或者启动时,报找不存在。 解决办法:第一时间检查Setting->Maven-Runner红圈中的√有没有选上。 二、有时候,明明依赖包存在,但是Maven页签中…

SI3262 低功耗 SOC +13.56mhz刷卡+触摸三合一芯片,适用于智能锁方案

Si3262 是一款高度集成的低功耗 SOC 芯片,其集成了基于 RISC-V 核的低功耗MCU 和工作在 13.56MHz 的非接触式读写器模块。 MCU 模块具有低功耗、Low Pin Count、宽电压工作范围,集成了13/14/15/16 位精度的 ADC、LVD、UART、SPI、I2C、TIMER、WUP、IWDG、…

【FAQ】安防视频监控/视频汇聚平台EasyCVR服务重启,海康SDK设备无法上线的原因排查

TSINGSEE青犀视频监控汇聚平台EasyCVR可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。旭帆科技平台既具备传统安防视频监控…

将目标检测项目移植到linux上出现OSERROR

在windows上运行项目正常,但是在centos9上运行出现找到资源,第一次遇到这个问题,通过代码回找,一步一步发现,读取数据没问题,但是在预测的时候无法读取,查到的资料 说明显示字体问题&#xff0c…

Maven中导入jQuery,前端页面中引用jQuery

第一步pom文件中,配置maven坐标。 第二步,在前端页面中引用jQuery 注:该前端页面需要在web根目录即webapp目录下。可认为在maven中导入jQuery后,jquery.min.js文件放在目录webapp/webjars/jquery/3.3.1下。

大模型扫盲之小白入门手记

本篇内容来自小米集团数据科学部负责人刘汉武老师的数据特训营笔记。不涉及深入的知识,仅在扫盲。 首先一个问题:大模型和大语言模型的区别是什么? 有人说大模型像是连接数据的星辰,能给我们提供前所未有的见解和洞察。现有的大模…

【精读Uboot】its文件语法

前面我们分析了SPL汇编的执行过程,在SPL之后就要进入另一个loader加载镜像了。在正式分析跳转流程之前,我们需要搞清楚在我们平时下载的imx-boot-xxx这个镜像是如何组成的。 在编译完Uboot、optee和ATF之后,会产生u-boot-spl.bin&#xff0c…