【MySQL】表的增删改查

目录

前言:

新增(Create):

查询(Retrieve):

别名:

去重:DISTINCT 

排序:ORDER BY :

条件查询:WHERE :

分页查询:LIMIT:

修改(Update):

删除(Delete):

内容总结:


前言:

在学会对数据库的操作后,我们就要进入到更为复杂的对表的操作,可以说MySQL的难点和数据库的核心操作基本都在对表的操作,包括后面要学到约束什么的基本也都是对表的操作,所以我们就要开始表的基本内容增删改查(CRUD)。

CRUD 即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写。

为了方便叙述下面均采用下面参数的表(student)来进行表的各类操作的演示。

新增(Create):

语法:

INSERT [INTO] table_name [(column [, column] ...)] VALUES (value_list) [, (value_list)] ...value_list: value, [, value] ...

小写简单版:

在表名后面可以指定某些列用括号括起来,里面的参数用逗号分开,values要对应。

基本语法如上,下面为它的多种用法👍👍👍。

(1)单行数据 + 全列插入

insert into student values ('唐三藏',65,71,83);

(2)多行数据 + 全列插入

如果可以的话我们是更加推荐多行数据插入的因为这样只需要向数据库发起一次请求,效率肯定要比访问数据库多次要高得多。

用逗号隔开即可。

insert into student values ('孙悟空', 81,45,63), ('张三', 73,84,56);

(3)多行数据 + 指定列插入

insert into student (name,math) values ('李四', 35), ('王五',83);

还有一个单行数据 + 指点列插入,这个由于和前面的这些类似,这里就不再演示。 

最终插入的数据如下:

扩展SQL语言特性:

友友们可以看看下面这个SQL语句,math的类型是int,但是这里插入varchar类型却显示成功了,这是为什么呢?

解释如下: SQL是一个“弱类型”的编程语言,和Java是不太一样的(强类型),当然C语言也是弱类型语言,那么我们如何理解弱类型和强类型呢?

在一个语言中,越是支持“隐式类型转换”,类型系统就越弱,越不支持“隐式类型转换”类型系统就越强,我们在学习Java的过程中不难看到Java基本都要自己手动转换(例如字符和整形,在c语言中二者可以直接相减,在Java中我们要进行手动转换后才能运算)。

查询(Retrieve):

语法:

SELECT [DISTINCT] {* | {column [, column] ...} [FROM table_name][WHERE ...][ORDER BY column [ASC | DESC], ...]LIMIT ...

简单小写如下: 

(1)全列查询:

用法如下:

SELECT * FROM exam_result;

查找我们上面插入的数据。

但是在通常情况下不建议使用 * 进行全列查询。

原因主要有以下两点: 

(1)查询的列越多,需要传输的数据量越大,数据的压力越大。

(2)可能会影响到索引的使用。

(2)指定列查询:

SELECT id, name, english FROM exam_result;

 注意:指定列的顺序不需要按定义表的顺序来。

(3)查询字段为表达式: 

-- 表达式不包含字段
SELECT id, name, 10 FROM exam_result;
-- 表达式包含一个字段
SELECT id, name, english + 10 FROM exam_result;
-- 表达式包含多个字段
SELECT id, name, chinese + math + english FROM exam_result;

运用我们上面演示来进行。

注意:还记得一开始就和大家说的,MySQL是一个“客户端-服务器”结构的程序,此时数据是存储在服务器上的硬盘上的。上述的表达式查询,只是针对服务器响应得到的临时结果进行了计算,不会影响硬盘上存储的数据本身。

别名:

为查询结果中的列指定别名,表示返回的结果集中,以别名作为该列的名称,语法:

SELECT column [AS] alias_name [...] FROM table_name;

用法如下: 

去重:DISTINCT 

使用DISTINCT关键字对某列数据进行去重:

语法:

演示如下: 

使用distinct语句:

排序:ORDER BY :

具备排序功能我们才能更好的管理数据。

语法:

-- ASC 为升序(从小到大)
-- DESC 为降序(从大到小)
-- 默认为 ASC
SELECT ... FROM table_name [WHERE ...] ORDER BY column [ASC|DESC], [...];

小写: 

注意点:

(1)没有 ORDER BY 子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序。

(2)NULL 数据排序,视为比任何值都小,升序出现在最上面,降序出现在最下面  。

针对一列排序:

演示如下:

使用表达式及别名排序:

演示如下:这里会出现NULL的原因是,元素只要和NULL发生运算都为NULL。

可以对多个字段进行排序,排序优先级随书写顺序:

演示如下:

原始数据如下:我们要对math和english排序,math的优先级大于english

排序前:

排序后:

降序排序:

默认排序是升序,我们可以在要排序的列后面加一个desc就可以升序排序。

条件查询:WHERE :

比较运算符:

运算符说明
>, >=,<,<=大于,大于等于,小于,小于等于
=等于,NULL 不安全,例如 NULL = NULL 的结果是 NULL
<=>等于,NULL 安全,例如 NULL NULL 的结果是 TRUE(1)
!=, <>不等于
BETWEEN a0 AND a1范围匹配,[a0, a1],如果 a0 <= value <= a1,返回 TRUE(1)
IN (option, ...)如果是 option 中的任意一个,返回 TRUE(1)
IS NULL是 NULL
IS NOT NULL不是 NULL
LIKE模糊匹配。% 表示任意多个(包括 0 个)任意字符;_ 表示任意一个字符

逻辑运算符:

运算符说明
AND多个条件必须都为 TRUE(1),结果才是 TRUE(1)
OR任意一个条件为 TRUE(1), 结果为 TRUE(1)
NOT条件为 TRUE(1),结果为 FALSE(0)

 注意点:

(1)WHERE条件可以使用表达式,但不能使用别名。

(2)AND的优先级高于OR,在同时使用时,需要使用小括号()包裹优先执行的部分。

这里给大家解释一下为什么在使用where表达式不可以使用别名而order by却可以。这是因为一个SQL的执行顺序:

(1)遍历表

(2)带入条件(where)

(3)计算列名中的表达式(定义别名)

(4)排序/聚合等操作

 我们可以看见带入条件的顺序在定义别名之前,所以在where中不能够使用别名。

上述的演示如下🌸🌸🌸:

1.基本查询:

这个和一般语言的用法差不多。

-- 查询英语不及格的同学及英语成绩 ( < 60 )
SELECT name, english FROM exam_result WHERE english < 60;
-- 查询语文成绩好于英语成绩的同学
SELECT name, chinese, english FROM exam_result WHERE chinese > english;
-- 查询总分在 200 分以下的同学
SELECT name, chinese + math + english 总分 FROM exam_result WHERE chinese + math + english < 200;

 2.AND与OR:

-- 查询语文成绩大于80分,且英语成绩大于80分的同学
SELECT * FROM exam_result WHERE chinese > 80 and english > 80;
-- 查询语文成绩大于80分,或英语成绩大于80分的同学
SELECT * FROM exam_result WHERE chinese > 80 or english > 80;
-- 观察AND 和 OR 的优先级:
SELECT * FROM exam_result WHERE chinese > 80 or math>70 and english > 70;
SELECT * FROM exam_result WHERE (chinese > 80 or math>70) and english > 70;

 这里和我们一般学的语言&& 和 || 不一样友友们要区分清楚。

3.范围查询:

(1)BETWEEN ... AND ...  

语法:

-- 查询语文成绩在 [80, 90] 分的同学及语文成绩
SELECT name, chinese FROM exam_result WHERE chinese BETWEEN 80 AND 90;
-- 使用 AND 也可以实现
SELECT name, chinese FROM exam_result WHERE chinese >= 80 AND chinese 
<= 90;

注意我们一般语言的范围默认是左闭右开,这里的between and 是左闭右闭。 

(2)IN

语法:

-- 查询数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩
SELECT name, math FROM exam_result WHERE math IN (58, 59, 98, 99);
-- 使用 OR 也可以实现
SELECT name, math FROM exam_result WHERE math = 58 OR math = 59 OR math 
= 98 OR math = 99;

where是连续的,in就是一个一个点。

4.模糊查询:LIKE

-- % 匹配任意多个(包括 0 个)字符
SELECT name FROM exam_result WHERE name LIKE '孙%';-- 匹配到孙悟空、孙权
-- _ 匹配严格的一个任意字符
SELECT name FROM exam_result WHERE name LIKE '孙_';-- 匹配到孙权

 “ = ” 是精确查询,要求查询出的结果和条件中的指定的内容完全一致。

“ like ” 是模糊查询,不要求完全一致,只要有一部分一致即可。这里需要引入通配符。注意:*不是like的通配符,like的通配符是“%”,“_”.

%:可以匹配任意多个字符(包括0),而_不能匹配0个字符。

例如:

 like这种模糊匹配在SQL中要慎用,因为开销很大,性能低下,本来SQL就不适合做这种😭😭😭。

5.NULL 的查询:IS [NOT] NULL  

-- 查询 qq_mail 已知的同学姓名
SELECT name, qq_mail FROM student WHERE qq_mail IS NOT NULL;
-- 查询 qq_mail 未知的同学姓名
SELECT name, qq_mail FROM student WHERE qq_mail IS NULL;

这个简单就是和英文句子的意思一样。

分页查询:LIMIT:

有的时候虽然是进行条件查询,但是查询到的结果仍然非常多(例如浏览器就给你进行进行分页)

语法:

-- 起始下标为 0
-- 从 0 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n;
-- 从 s 开始,筛选 n 条结果
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT s, n;
-- 从 s 开始,筛选 n 条结果,比第二种用法更明确,建议使用
SELECT ... FROM table_name [WHERE ...] [ORDER BY ...] LIMIT n OFFSET s;

总共有三种用法: 

1.limit n;

从 0 开始,筛选 n 条结果

2.limit s, n;

从 s 开始,筛选 n 条结果

3.limit n offset s;

从 s 开始,筛选 n 条结果,比第二种用法更明确,建议使用这种

修改(Update):

语法:

UPDATE table_name SET column = expr [, column = expr ...][WHERE ...] [ORDER BY ...] [LIMIT ...]

小写:

也可以一次修改多个列,set后面写多组列用‘ ,’ 分别进行 = 赋值即可。

例如:

原来唐三藏的math为71现在我们要把它改成98. 

修改结果如下:

注意:

(1)update 会修改服务器硬盘上存储的数据,且此操作不能撤回。

(2)注意MySQL语法不支持math += 10;这种写法,只能math = math + 10;

删除(Delete):

语法:

DELETE FROM  table_name [WHERE ...] [ORDER BY ...] [LIMIT ...]

 

删除唐三藏的数据。 

如果不指定条件的话就是删除所有数据,它和drop table 的区别是:drop是表和内容都没了,delete是只有数据没了,表还在。

内容总结:

新增:

-- 单行插入
insert into 表(字段1, ..., 字段N) values (value1, ..., value N);
-- 多行插入
insert into 表(字段1, ..., 字段N) values 
(value1, ...),
(value2, ...),
(value3, ...);

查询:

-- 全列查询
select * from 表
-- 指定列查询
select 字段1,字段2... from 表
-- 查询表达式字段
select 字段1+100,字段2+字段3 from 表
-- 别名
select 字段1 别名1, 字段2 别名2 from 表
-- 去重DISTINCT
select distinct 字段 from 表
-- 排序ORDER BY
select * from 表 order by 排序字段
-- 条件查询WHERE:
-- (1)比较运算符 (2)BETWEEN ... AND ... (3)IN (4)IS NULL (5)LIKE (6)AND (7)OR 
(8)NOT
select * from 表 where 条件

修改:

update 表 set 字段1=value1, 字段2=value2... where 条件

删除:

delete from 表 where 条件

希望友友们要自己实际操作一下,本身和数据结构比起来就不难,就是一个熟练度的问题。

结语:

其实写博客不仅仅是为了教大家,同时这也有利于我巩固知识点,和做一个学习的总结,由于作者水平有限,对文章有任何问题还请指出,非常感谢。如果大家有所收获的话还请不要吝啬你们的点赞收藏和关注,这可以激励我写出更加优秀的文章。

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

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

相关文章

c++实数排序

例&#xff1a;数的三次方跟 描述&#xff1a;给定一个浮点数n&#xff0c;求它的三次方根。 输入描述&#xff1a;一个浮点数 输出描述&#xff1a;问题的解 保留6位小数 #include<bits/stdc.h> using namespace std; double n,eps1e-8; bool check (double x){retu…

【新手入门必看】从零开始学指针

我使用VS CODEMSYS2的编译环境进行学习&#xff0c;想使用VS CODE进行C/C代码编写的小伙伴参考这篇文章进行环境配置VS Code 配置 C/C 编程运行环境&#xff08;保姆级教程&#xff09; 一、指针的引入 指针地址 #include <stdio.h>int main() {int a 10;printf(&quo…

Git的操作和使用

一、基本操作 1、创建git本地仓库 &#xff08;1&#xff09;创建目录&#xff1a;mkdir gitcode &#xff08;2&#xff09;进入目录&#xff1a;cd gitcode/ &#xff08;3&#xff09;查询目录内容&#xff1a;ls &#xff08;4&#xff09;在当前目录下创建git本地仓库…

java算法day3

移除链表元素设计链表翻转链表两两交换链表中的结点 移除链表元素 ps&#xff1a;有时候感觉到底要不要写特判&#xff0c;你想到了就写&#xff01;因为一般特判有一劳永逸的作用。 解法有两种&#xff0c;一种是不用虚拟头结点&#xff0c;另一种就是用虚拟头结点。 这里我…

React-基础语法学习

1、教程&#xff1a;井字棋游戏 本教程将引导你逐步实现一个简单的井字棋游戏&#xff0c;并且不需要你对 React 有任何了解。在此过程中你会学习到一些编写 React 程序的基本知识&#xff0c;完全理解它们可以让你对 React 有比较深入的理解。 1.1、教程分成以下几个部分&am…

3D感知生成对抗网络的高斯溅射解码器

Gaussian Splatting Decoder for 3D-aware Generative Adversarial Networks 3D感知生成对抗网络的高斯溅射解码器 Florian Barthel1, 2  Arian Beckmann1  Wieland Morgenstern1  Anna Hilsmann1  Peter Eisert1,2 Florian Barthel 1, 2 阿里安贝克曼Wieland晨星Anna Hils…

【Godot4自学手册】第三十九节利用shader(着色器)给游戏添加一层雾气效果

今天&#xff0c;主要是利用shader给游戏给地宫场景添加一层雾气效果&#xff0c;增加一下气氛&#xff0c;先看一下效果&#xff1a; 一、新建ParallaxBackground根节点 新建场景&#xff0c;根节点选择ParallaxBackground&#xff0c;命名为Fog&#xff0c;然后将该场景保…

不要小看在线文档编辑工具,它才是提高工作效率的法宝

在数字化的今天&#xff0c;工作方式正变得越来越灵活&#xff0c;远程办公和团队协作已成日常。这个时候&#xff0c;传统的文档处理方式已经无法满足快速发展的业务需求。在线文档编辑工具&#xff0c;正逐渐成为提高团队工作效率的秘密武器。它能够让团队成员无论身处何地&a…

从预训练损失的角度,理解语言模型的涌现能力

原文&#xff1a;Understanding Emergent Abilities of Language Models from the Loss Perspective 摘要 本文从预训练损失的角度重新审视语言模型的涌现能力&#xff0c;挑战了以往以模型大小或训练计算量为标准的观念。通过实验&#xff0c;作者发现预训练损失是预测下游任…

【剪映专业版】15绿幕抠图:应用技巧、注意事项

视频课程&#xff1a;B站有知公开课【剪映电脑版教程】 1.绿幕抠图 背景为绿色的素材&#xff08;其他颜色也可以扣取&#xff0c;只是绿色背景更普遍、抠图效果更好&#xff09; 选择色度抠图&#xff0c;通过取色器选取背景颜色&#xff0c;调整强度实现抠图 剪映的色度抠…

“我舍不得”用英语怎么说?柯桥日常英语口语培训

“我舍不得”用英语怎么说&#xff1f; “舍不得”的英文表达是&#xff1a;Cant bear to 不忍心&#xff0c;不舍得 例句&#xff1a; Time flies. I cant bear to leave you. 时间过的好快啊&#xff0c;我真舍不得离开你。 I cant bear to see you cry. 我真舍不得你…

《QT实用小工具·三十四》Qt/QML使用WebEngine展示的百度ECharts图表Demo

1、概述 源码放在文章末尾 该项目实现了百度ECharts图表的样式&#xff0c;效果demo如下所示&#xff1a; 项目部分代码如下所示&#xff1a; #include <QGuiApplication> #include <QQmlApplicationEngine> #include <QtWebEngine>int main(int argc, ch…

小成本搏大流量:微信/支付宝小程序搜索排名优化

随着移动互联网的快速发展&#xff0c;小程序已成为企业和个人开发者重要的流量入口和业务承载平台。而小程序搜索排名则是影响小程序曝光量、用户获取及业务转化的关键因素。小柚在本文和大家探讨如何制定有效的优化方案&#xff0c;提升小程序在搜索结果中的排名。 首先跟我…

基于docker的Jenkin的服务平台搭建

项目拓扑图 项目环境: jenkins-2.440 sonarqube-9.9.4 apache-maven-3.9.6 gitlab-ce-12.4.2 java17 docker20 harbor.v2.6.0 centos7.9 项目目的: 模拟企业构建一个流行的持续集成和持续部署环境,可以更轻松地创建和管理构建环境&#xff0c;实现自动化构建和部署应用程序的…

Ubuntu 微调训练ChatGLM3大语言模型

Ubuntu 微调训练ChatGLM3大语言模型 LLaMA Factory 的 LoRA 微调提供了 3.7 倍的加速比&#xff0c;同时在广告文案生成任务上取得了更高的 Rouge 分数。结合 4 比特量化技术&#xff0c;LLaMA Factory 的 QLoRA 微调进一步降低了 GPU 显存消耗。 https://github.com/hiyouga…

累加(C语言)

一、题目&#xff1b; 二、N-S流程图&#xff1b; 三、运行结果&#xff1b; 四、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>int main() {//初始化变量值&#xff1b;int i 0;int j 0;int n 5;int result 0;int sum 0;//运算&#…

牛客-小乐乐与欧几里得

目录 题目 描述 输入描述&#xff1a; 输出描述&#xff1a; 示例1 示例2 解题 题目 描述 小乐乐最近在课上学习了如何求两个正整数的最大公约数与最小公倍数&#xff0c;但是他竟然不会求两个正整数的最大公约数与最小公倍数之和&#xff0c;请你帮助他解决这个问题。 …

进程控制第二弹(进程程序替换)

文章目录 代码现象基本原理多进程版本实例基本原理 使用所有的替换方法&#xff0c;并且认识函数的参数含义execlexecvexeclp、execvpexecvpe 总结 代码现象 #include<stdio.h> #include<unistd.h> int main() { printf("testexec begin! ...\…

数据安全全面防护

what 通过采用各种有效技术和管理措施来保护网络系统的正常运行&#xff0c;从而保证数据的可用性&#xff0c;机密性&#xff0c;完整性。 ---网络安全防护体系建设三同步--规划 建设 运行 数据安全的三大基本特征 可用性 数据在需要时可用且可访问&#xff0c;为实现可用…

算法课程笔记——STL键值对map

map当下标无限的数组 重点是对应关系&#xff0c;一般不修改compare 类比set 没有lowerbound&#xff0c;因为遍历是无序的 ; map不能用sort函数排序 但可用vector转化为map使用 std::set<std::pair<TKEY, mutable TVAL> > ≈ std::map<TKEY, TVAL>