【MySQL】表的基本增删查改(结合案例)

news2024/12/25 22:34:39

文章目录

  • 1.前言
  • 2.插入数据(Create)
    • 2.1案例
    • 2.2单行数据+全列插入
    • 2.3多行数据+指定列插入
    • 2.4插入否则更新
    • 2.5替换
  • 3. 读取数据(Retireve)
    • 3.1案例
    • 3.2全列查询
    • 3.3指定列查询
    • 3.4查询字段为表达式
    • 3.5为查询结果起别名
    • 3.6去重
    • 3.7where条件
      • 3.7.1案例
    • 3.8排序
    • 3.9筛选分页
  • 4. 修改数据(Update)
  • 5.删除数据(Delete)
    • 5.1delete删除
    • 5.2截断表
    • 5.3truncate和delete的区别
  • 6.将查询结果当作数据进行多行插入
  • 7.聚合函数
  • 8.分析基本查询的执行顺序
  • 9.分组查询
  • 10.SQL查询的顺序

1.前言

在前面我们学习了针对库的操作以及针对表结构的操作,下面我们来学习针对表中数据的操作。对数据操作的类型无非就是C(创建)R(读取)U(修改)D(删除),针对以上四种类型的操作,结合案例展开讨论

2.插入数据(Create)

语法:

insert
	表
	插入列
values
   数据

2.1案例

现创建一张学生表,表结构如下:

CREATE TABLE students (
   id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
   sn INT NOT NULL UNIQUE COMMENT '学号',
   name VARCHAR(20) NOT NULL,
   qq VARCHAR(20)
);

在这里插入图片描述

2.2单行数据+全列插入

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.3多行数据+指定列插入

在这里插入图片描述

2.4插入否则更新

如果我们再插入数据时遇到了主键或者唯一键冲突,我们选择性的进行同步操作,例如:
在这里插入图片描述

在这里插入图片描述
使用ON DUPLICATE KEY UPDATE可以在发生冲突之后执行update语句。

2.5替换

主键或者唯一键发生冲突,删除再插入
没有发生冲突就直接插入
在这里插入图片描述

3. 读取数据(Retireve)

读取数据其实就是查询数据,查询数据使用select语句
语法:

select {cloumn1,cloumn2..} from {table1,table2...} [where...] [order by...] [goup by...] [limit...]

3.1案例

创建一个exam_result表记录学生的考试成绩:

CREATE TABLE exam_result ( 
 id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT, 
 name VARCHAR(20) NOT NULL COMMENT '同学姓名', 
 chinese float DEFAULT 0.0 COMMENT '语文成绩', 
 math float DEFAULT 0.0 COMMENT '数学成绩', 
 english float DEFAULT 0.0 COMMENT '英语成绩' 
); 

给出一组数据用于测试:

INSERT INTO exam_result (name, chinese, math, english) VALUES 
 ('唐三藏', 67, 98, 56), 
 ('孙悟空', 87, 78, 77), 
 ('猪悟能', 88, 98, 90), 
 ('曹孟德', 82, 84, 67), 
 ('刘玄德', 55, 85, 45), 
 ('孙权', 70, 73, 78), 
 ('宋公明', 75, 65, 30);//多行全列插入

3.2全列查询

在这里插入图片描述

3.3指定列查询

假设要查看所有同学的数学成绩以及姓名
在这里插入图片描述

3.4查询字段为表达式

假设要查询所有同学的总成绩
在这里插入图片描述

3.5为查询结果起别名

使用as可以给一个表达式或者是一张表或者一个字段起别名,例如还是查询所有同学的总成绩:
在这里插入图片描述
其中as也可以省略不写

3.6去重

可以在查询字段前添加distinct表示对该字段去重,例如查询所有同学的数学成绩:
去重前:
在这里插入图片描述
去重后
在这里插入图片描述
这样就没有重复的数学成绩了。

3.7where条件

使用where可以保证查询数据的准确性。
下面给出常见的比较运算符
在这里插入图片描述
逻辑运算符
在这里插入图片描述
下面结合具体案例来使用where

3.7.1案例

  • 案例一:查询英语成绩不及格的同学及其英语成绩
    在这里插入图片描述
  • 案例二:语文成绩在 [80, 90] 分的同学及语文成绩
    在这里插入图片描述
    在这里插入图片描述
  • 案例三:数学成绩是 98 或者 78的 同学及数学成绩
    在这里插入图片描述
  • 案例四:查询姓孙的同学的成绩
    在这里插入图片描述
  • 案例五:查询名字姓孙某(两个字)同学的成绩
    在这里插入图片描述
  • 案例六:在students表中查询qq为NULL的同学的语文成绩
    在这里插入图片描述

3.8排序

语法:

select 
	聚合函数,
	列(要求出现在group by的后面)
fromwhere 
	筛选条件
order by 
	cloumn asc;//升序
	cloumn desc;//降序

  • 案例1:查询所有同学的数学成绩并按照升序显示
    在这里插入图片描述
  • 案例2:查询所有同学的总成绩并安装降序排序
    在这里插入图片描述

3.9筛选分页

语法:

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

比如查询所有同学的总成绩,显示分数最高的三个人
在这里插入图片描述
也可以使用offset:
在这里插入图片描述

4. 修改数据(Update)

语法:

UPDATE table_name SET column = expr [, column = expr ...] 
 [WHERE ...] [ORDER BY ...] [LIMIT ...] 
  • 案例:将孙某同学的成绩改为60分
    在这里插入图片描述

5.删除数据(Delete)

5.1delete删除

delete可以删除表中的部分数据,也可以删除全部数据。delete并不会影响表的结构。
语法:

DELETE FROM table_name [WHERE ...] [ORDER BY ...] [LIMIT ...] 
  • 案例1:删除孙悟空同学的考试成绩
    查看原数据:
    在这里插入图片描述
    删除后:
    在这里插入图片描述

  • 案例2:删除整张表的数据
    delete table table_name表示删除table_name表的数据,这里不做演示。

5.2截断表

截断truncate和delete都是对表中数据进行删除,truncate只能用来删除表中的所有数据
语法:

TRUNCATE TABLE table_name;

5.3truncate和delete的区别

  • 作用范围:truncate只能作用于整个表不能带条件,而delete可以删除表中部分数据且可以带条件
  • 速度和性能:truncate是批量删除,delete是逐行删除。truncate删除数据之后并不会留下日志记录,而delete会,所以truncate的速度较快
  • 重置表的索引:除了删除数据之外,truncate还会重置表中的索引值,比如自增键(auto_incream)又变为了1。
    总结:如果希望删除表中所有数据其希望操作更快,用truncate.如果希望删除操作能回滚即恢复数据,或者只是删除部分数据,那就用delete

6.将查询结果当作数据进行多行插入

语法:

INSERT INTO table_name [(column [, column ...])] SELECT ... 

mysql支持将select查询到的结果作为数据对某一张表进行多行插入,比如当我们想复制一个表中的数据到另一个表里。
现给出原始表数据:

-- 创建原数据表 
 
CREATE TABLE duplicate_table (id int, name varchar(20)); 
Query OK, 0 rows affected (0.01 sec) 
 
-- 插入测试数据 
INSERT INTO duplicate_table VALUES 
 (100, 'aaa'), 
 (100, 'aaa'), 
 (200, 'bbb'), 
 (200, 'bbb'), 
 (200, 'bbb'), 
 (300, 'ccc'); 

在这里插入图片描述

  • 案例:删除duplicate_table表中的重复数据
    思路:创建一张空表,表结构和duplicate_table保持一致,然后将duplicate_table去重查询到的数据插入到新表中,再将新表重命名为duplicate_table
    其中复制一个表的结构我们可以使用like,例如:
    在这里插入图片描述

duplicate_table去重查询到的数据插入到新表中:
在这里插入图片描述
重命名表名
在这里插入图片描述
在这里插入图片描述

7.聚合函数

MySQL中的聚合函数主要用于对一组数据进行计算,返回单个值。常见的聚合函数包括SUM(求和)、AVG(平均值)、MAX(最大值)、MIN(最小值)、COUNT(计数)等。

在这里插入图片描述

  • 案例:统计班级有多少学生
    在这里插入图片描述
  • 案例:统计数学成绩总分
    在这里插入图片描述
  • 案例:统计数学的平均成绩
    在这里插入图片描述
  • 案例:返回数学成绩做高分
    在这里插入图片描述

8.分析基本查询的执行顺序

比如以下语句:
在这里插入图片描述

执行的顺序为:

  1. from exam_result
  2. where math>60
  3. select name,math
  4. order by math asc

9.分组查询

在select中使用group by 子句可以对指定列进行分组查询
语法:

select 
	聚合函数,
	列(要求出现在group by的后面)
fromwhere 
	筛选条件
group by 
	分组的列表
having
   条件查询
order by 
	排序
limit
   分页

其中having表示对分组结果进行条件筛选,执行顺序在group by之后。

下面有一张员工表EMP,字段包括员工工资sal、部门号deptno,岗位job。具体内容如下:
在这里插入图片描述

  • 案例1:显示每个部门的平均工资和最高工资
    思路:按照部门号进行分组,于是我们得到了诺干个子表,子表属于同一部门的。再聚合统计每个子表的平均工资的最高工资好平均工资。
    sql语句:
select deptno,max(sal),avg(sal) from emp group by deptno;

在这里插入图片描述

  • 案例2:显示每个部门的每种岗位的平均工资和最高工资
    思路:先按部门号分组,再按岗位分组,再聚合统计每个组的平均工资和最高工资
    sql语句:
select deptno,max(sal),avg(sal) from emp goup by deptno,joib;

在这里插入图片描述

  • 案例3:统计平均工资低于2000的部门和它的平均工资
    思路:先按部门分组,再对每个组求平均工资,最后使用having 对分组结果进行查询,即查询部门平均工资低于2000的
    sql语句:
select avg(sal) avg_sal from emp group by deptno having avg(sal)<2000;

在这里插入图片描述

10.SQL查询的顺序

from > where > group by > having> select > distinct > order by > limit

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

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

相关文章

Post Microsoft Build and AI Day 北京开发者日

Microsoft Build 开发者大会 Microsoft Build 开发者大会是微软每年一次的开发者技术盛会&#xff0c;旨在向全球开发者展示微软最新的技术、产品和服务。 刚刚过去的 2024 Microsoft Build 开发者大会围绕 Copilot、生成式 AI、应用程序安全、云平台、低代码等多个技术方向&a…

运维系列.在Docker中使用Grafana

运维专题 在Docker中使用Grafana - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:https://blog.csdn.net/qq_2855026…

Java对象的序列化与反序列化

序列化和反序列化是什么 当两个进程远程通信时&#xff0c;彼此可以发送各种类型的数据。无论是何种类型的数据&#xff0c;都会以二进制序列的形式在网络上传送。比如&#xff1a;我们可以通过http协议发生字符串信息&#xff1b;我们也可以在网络上直接发生Java对象。发送方…

【linux】信号(三)

本章节将会围绕信号处理进行展开讲解 目录 回顾一下&#xff1a;历史问题&#xff1a;内核态 VS 用户态地址空间&#xff1a;键盘的输出如何被检测到&#xff1a;OS如何正常运行&#xff1a;如何执行系统调用&#xff1a; 信号的处理&#xff1a;sigaction&#xff1a;信号的…

QML学习十九:ttf字体库使用

一、前言 在使用QML时&#xff0c;常常自定义按钮&#xff0c;按钮上有显示个图标&#xff0c;其实&#xff0c;那不是图标&#xff0c;是文本&#xff0c;如何显示&#xff1f; 本篇记录&#xff0c;如何导入阿里巴巴字体库&#xff0c;并调用显示。 二、阿里巴巴字体库下载…

分布式系统设计指南

目录 一、分布式简介 二、分布式系统核心概念 2.1 CAP 理论 2.2 BASE 原理 三、分布式系统设计 3.1 微服务拆分 3.2 通信模型 3.3 负载均衡 3.4 数据一致性 3.5 容错限流 3.6 扩展性 3.7 监控预警 3.8 自动化运维 一、分布式简介 分布式系统是由单体应用发展而来的&#xff…

统计绘图 | 既能统计分析又能可视化绘制的技能

在典型的探索性数据分析工作流程中&#xff0c;数据可视化和统计建模是两个不同的阶段&#xff0c;而我们也希望能够在最终的可视化结果中将相关统计指标呈现出来&#xff0c;如何让将两种有效结合&#xff0c;使得数据探索更加简单快捷呢&#xff1f;今天这篇推文就告诉你如何…

使用 Scapy 库编写 TCP 窗口大小探测攻击脚本

一、介绍 1.1 概述 TCP窗口大小探测攻击是一种信息收集攻击&#xff0c;攻击者通过向目标服务器发送特制的TCP数据包&#xff0c;探测目标服务器的TCP接收窗口大小&#xff08;TCP Window Size&#xff09;。了解目标服务器的TCP接收窗口大小&#xff0c;可以帮助攻击者优化后…

Spring Web MVC之过滤器Filter和拦截器HandlerInterceptor的区别和用法

作用时机不一样 Spring 框架有一个很重要的类DispatcherServlet。这个类继承了HttpServlet&#xff0c;HttpServlet实现了Servlet接口。相当于图片中的Servlet。所有和Spring框架相关配置&#xff0c;例如注解、xml配置、其他数据库连接配置、bean配置、拦截器配置等其他配置&…

深度学习研究生的职业前景:未来趋势与机遇

deep learning 深度学习研究生的职业前景&#xff1a;未来趋势与机遇一、深度学习的应用领域1. 计算机视觉2. 自然语言处理&#xff08;NLP&#xff09;3. 数据分析4. 游戏开发5. 健康医疗 二、职业机遇与挑战1. 工作机会2. 竞争与挑战3. 薪资前景 三、职业发展策略对于深度学习…

国外创意二维码应用:飞利浦旧物翻新活动,传播可持续性消费的重要性!

你知道去年有超过1000万件礼物被扔进了垃圾场吗? 这些被丢弃的物品中有许多仍在使用&#xff0c;飞利浦希望改变这种浪费现象。 去年的地球日&#xff0c;飞利浦策划了一场名为“Better than New” 的二维码营销活动。他们发布了一个视频&#xff0c;通过这个短视频将所有最终…

钉钉魔点指纹考勤机多少钱一台,指纹门禁考勤一体机价格

钉钉魔点指纹考勤机一台多少钱呢&#xff0c;指纹门禁考勤一体机的价格又是多少 钉钉魔点 X2 智能指纹考勤门禁一体机的参考价格是 359 元。 其具体参数情况如下&#xff1a; 产品类型&#xff1a;属于指纹考勤门禁一体机&#xff1b; 验证方式&#xff1a;为电容指纹&…

4、优化阶段

优化概述 编译程序总框架&#xff1a; 优化:对程序进行各种等价变换&#xff0c;使得从变换后的程序出发&#xff0c;能生成更有效的目标代码。 等价:不改变程序的运行结果。 有效:目标代码运行时间短&#xff0c;占用存储空间小。 >目的 产生更高效的代码 >遵循的原则 …

618值得购买的东西有哪些?618四款必囤好物清单分享!

随着618购物狂欢节的脚步日益临近&#xff0c;身为数码领域的资深爱好者&#xff0c;我深感有必要为大家推荐一系列经过精心挑选的数码产品精选。无论是热衷于科技前沿的探索者&#xff0c;还是希望通过智能设备提升生活品质的时尚达人&#xff0c;本文所介绍的每一款数码产品都…

MT2096 数列分段

代码&#xff1a; #include <bits/stdc.h> using namespace std; const int N 1e5 10; int n, m; int a[N]; int ans 1; int main() {cin >> n >> m;for (int i 1; i < n; i)cin >> a[i];int num 0;for (int i 1; i < n; i){if (num a[i…

(1)图像识别yolov5—安装教程

目录 1、安装YOLOv5: 2、下载预训练模型: 3、识别示例图片: 1、安装YOLOv5: 首先,你需要在你的计算机上下载 YOLOv5 的文件包,下载链接:https://github.com/ultralytics/yolov5。下载后对压缩文件进行解压。 通常使用 YOLOv5 识别物体,需要安装必要的 依赖…

DataX(DataX简介、部署、同步数据)

DataX&#xff08;DataX简介、部署、同步数据&#xff09; ☀快乐无限 法力无边 目录 DataX&#xff08;DataX简介、部署、同步数据&#xff09; 1.DataX简介 1&#xff09;数据采集模块&#xff1a; 2&#xff09;数据写入模块&#xff1a; 2.DataX部署 1&#xff09;Da…

《AI企业级知识库》-rasa爆改中文版本-实战!

阿丹&#xff1a; 之前有同学反应分享的东西有点概念化&#xff0c;表示不看着代码无法更深刻能理解。那么今天直接上代码&#xff01;&#xff01;&#xff01; 有两种方式使用自己训练好的nlu 1、rasa与nul分开启动&#xff0c;就是在rasa中的配置中配置好目标对应的nlu的服…

语法04 C++ 标准输入语句

标准输入 使用格式&#xff1a;cin >> 输入的意思就是把一个值放到变量里面去&#xff0c;也就是变量的赋值&#xff0c;这个值是由我们自己输入的。 (注意:输入变量前要先定义&#xff0c;输入完之后要按Enter键。) 输入多个变量&#xff0c;与输出类似&#xff0c;…

全球知名哲学家思想家教育家颜廷利:清明节的教育意义

在21世纪全球公认十大思想家的行列中&#xff0c;颜廷利大师以其独到的见解和深刻的哲学思考而备受推崇。随着清明节的临近&#xff0c;人们纷纷前往先人的墓地进行祭奠&#xff0c;其中烧纸钱是一项重要仪式。然而&#xff0c;亚洲十大顶级杰出人物、当代易学泰斗三大人物颜廷…