MySQL的CRUD操作函数介绍union和union all

news2025/1/17 5:59:43

目录

一. CRUD(增删改查)

1.1 SELECT(查询)

概念

语法

含义

 1.2 INSERT(新增)

概念

语法

含义

1.3 UPDATE(修改)

语法

含义

1.4 DELETE(删除)

语法

含义

二. 函数

2.1 常见函数

字符函数

数字函数

日期函数

2.2 流程控制函数

语法

 示例

2.3 聚合函数

三. UNION与UNION ALL

概念

语法

专业词解释

使用场景

实例

全列

单列

结论

思维导图


一. CRUD(增删改查)

1.1 SELECT(查询)

概念

查询数据是指从数据库中根据需求,使用不同的查询方式来获取不同的数据,是使用频率最高、最重要的操作。

语法

SELECT
{* | <字段列名>}
[FROM <表 1>, <表 2>…
[WHERE <表达式>
[GROUP BY <group by definition>
[HAVING <expression> [{<operator> <expression>}…]]
[ORDER BY <order by definition>]
[LIMIT[<offset>,] <row count>]
]

含义

  • {*|<字段列名>}  包含星号通配符的字段列表,表示所要查询字段的名称。
  • <表 1>,<表 2>…,表 1 和表 2 表示查询数据的来源,可以是单个或多个。
  • WHERE <表达式>  是可选项,如果选择该项,将限定查询数据必须满足该查询条件。
  • GROUP BY< 字段 >,该子句告诉 MySQL 如何显示查询出来的数据,并按照指定的字段分组。
  • [ORDER BY< 字段 >],该子句告诉 MySQL 按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序。
  • [LIMIT[<offset>,]<row count>],该子句告诉 MySQL 每次显示查询出来的数据条数。

 1.2 INSERT(新增)

概念

使用INSERT语句向数据库已有的表中插入一行或多行数据。

语法

  • INSERT…VALUES语句
INSERT INTO <表名> [ <列名1> [ , … <列名n>] ]
VALUES (值1) [… , (值n) ];
  • INSERT…SET语句

INSERT INTO <表名>
SET <列名1> = <值1>,
    <列名2> = <值2>,
    …

含义

  • <表名>:指定被操作的表名。
  • <列名>指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用 INSERT<表名>VALUES(…) 即可。
  • VALUES 或 VALUE 子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应。

由 INSERT 语句的两种形式可以看出:

  1. 使用 INSERT…VALUES 语句可以向表中插入一行数据,也可以插入多行数据;
  2. 使用 INSERT…SET 语句可以指定插入行中每列的值,也可以指定部分列的值;
  3. INSERT…SELECT 语句向表中插入其他表的数据。
  4. 采用 INSERT…SET 语句可以向表中插入部分列的值,这种方式更为灵活;
  5. INSERT…VALUES 语句可以一次插入多条数据。

1.3 UPDATE(修改)

语法

UPDATE <表名> SET 字段 1=值 1 [,字段 2=值 2… ] [WHERE 子句 ]
[ORDER BY 子句] [LIMIT 子句]

含义

  • <表名>:用于指定要更新的表名称。
  • SET 子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可用关键字 DEFAULT 表示列值。
  • WHERE 子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行。
  • ORDER BY 子句:可选项。用于限定表中的行被修改的次序。
  • LIMIT 子句:可选项。用于限定被修改的行数。

1.4 DELETE(删除)

语法

DELETE FROM <表名> [WHERE 子句] [ORDER BY 子句] [LIMIT 子句]

含义

  • <表名>:指定要删除数据的表名。
  • ORDER BY 子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。
  • WHERE 子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。
  • LIMIT 子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。

二. 函数

2.1 常见函数

字符函数

  • 转小写         LOWER('SQL Course') ➡sql course
  • 转大写         UPPER('SQL Course') ➡SQL COURSE
  • 拼接             CONCAT('hello','world') ➡helloworld
  • 截取             SUBSTR('helloworld',1,5) ➡hello
  • 长度              LENGTH('helloworld') ➡10
  • 字符出现索引值                 INSTR('helloworld','w') ➡6
  • 字符截取后半段                 TRIM('h' FROM 'helloworld') ➡elloworld
  • 字符替换                REPLACE('abcd','a','m') ➡mbcd

数字函数

  • 四舍五入         ROUND(98.1289, 2) ➡98.13
  • 截断                TRUNC(98.1289, 2) ➡98.12
  • 求余                MOD(1600,300) ➡100

日期函数

  • 获取当前日期         now()
  • 将日期格式的字符转换成指定格式的日期             STR_TO_DATE('9-13-1999', '%m-%d-%Y') ➡1999-09-13
  • 将日期转换成字符           DATE_FORMAT('2012/9/9', '%Y年%m月%d日') ➡2012年9月9日

2.2 流程控制函数

语法

CASE expr WHEN conparison_expr1 THEN return_expr1
[WHEN comparison_expr2 THEN return_expr2
WHEN comparison_exprn THEN return_exprn
ELSE else_expr]
END

 示例

查询同时存在01课程和02课程的情况

SELECT 
t3.*,
(CASE WHEN t1.cid = '01' THEN t1.score END)语文,
(CASE WHEN t2.cid = '02' THEN t2.score END)数学,
FROM
(SELECT *FROM t_mysql_score sc WHERE sc.cid = '01')t1,
(SELECT *FROM t_mysql_score sc WHERE sc.cid = '02')t2,
t_mysql_student t3
WHERE
t1.sid = t2.sid
AND t1.sid = t3.sid

查询会议信息(包含会议信息表数据,主持人姓名、审批人姓名、会议状态)

SELECT a.id, a.title, a.content, a.canyuzhe, a.liexizhe, a.zhuchiren, b.name, a.location,
DATE_FORMAT(a.startTime,'%Y-%m-%d %H:%i:%s')as startTime,
DATE_FORMAT(a.endTime,'%Y-%m-%d %H:%i:%s')as endTime,
a.state,
(case a.state
when 0 then '取消会议'
when 1 then '新建'
when 2 then '待审核'
when 3 then '驳回'
when 4 then '待开'
when 5 then '进行中'
when 6 then '开启投票'
else '结束会议' end
)as meetingState, a.seatPic, a.remark, a.auditor, c.name as auditorName
FROM t_oa_meeting_info a
inner join t_oa_user b on a.zhuchiren = b.id
left join t_oa_user c on a.auditor = c.id where 1=1;

2.3 聚合函数

sum求和、avg平均值、max最大值、min最小值、count计算个数

三. UNION与UNION ALL

概念

UNION:用于合并两个或多个SELECT语句的结果集,并去除重复的行。

UNION ALL: 用于合并两个或多个SELECT语句的结果集,包括重复的行。

语法

UNION:将多个SELECT语句放在一起,并使用UNION关键字将他们连接起来。每个SELECT语句的列数、列名和数据类型必须相同。

UNION ALL: 将多个SELECT语句放在一起,并使用UNION ALL关键字将他们连接起来。每个SELECT语句的列数、列名和数据类型可以不同。

专业词解释

UNION:UNION操作符执行去除重复行的操作,它通过对所有的结果集进行排序和比较来实现。

UNION ALL: UNION ALL操作符不执行去除重复行的操作,它直接将所有的结果集合并在一起。

使用场景

UNION:当需要合并多个查询结果,并且不希望出现重复行时,可以使用UNION操作符。它适用于数据需要去重的情况。

UNION ALL: 当需要合并多个查询结果,包括重复行时,可以使用UNION ALL操作符。它适用于不需要去重的情况,或者在已经确定结果不会有重复行的情况下。

实例

全列

初始数据

SELECT *from t_oa_meeting_info where id>=1 and id<=8;
SELECT *from t_oa_meeting_info where id>=6 and id<=10;

UNION

678只出现了一次

SELECT *from t_oa_meeting_info where id>=1 and id<=8
UNION
SELECT *from t_oa_meeting_info where id>=6 and id<=10;

UNION ALL 

678重复出现

SELECT *from t_oa_meeting_info where id>=1 and id<=8
UNION ALL
SELECT *from t_oa_meeting_info where id>=6 and id<=10;

单列

初始数据

SELECT id from t_oa_meeting_info where id>=1 and id<=8;
SELECT id from t_oa_meeting_info where id>=6 and id<=10;

UNION
678只出现了一次

SELECT id from t_oa_meeting_info where id>=1 and id<=8
UNION
SELECT id from t_oa_meeting_info where id>=6 and id<=10;

UNION ALL 

678重复出现

SELECT id from t_oa_meeting_info where id>=1 and id<=8
UNION ALL
SELECT id from t_oa_meeting_info where id>=6 and id<=10;

结论

所谓去重并不需要所有列相同。

思维导图

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

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

相关文章

Kotlin:Set其实是有插入的顺序?

MutableSet怎么能调用indexOf去获取它的插入顺序呢&#xff1f;参考官网Collections overview | Kotlin Documentationhttps://kotlinlang.org/docs/collections-overview.html#set翻不了墙的看下面 &#xff08;MutableSet的默认实现是LinkedHashSet&#xff0c;LinkedHashSet…

接口自动化技巧

使用postman发送上传接口方法&#xff1a; pytest运行完很多warning信息&#xff0c;如何去掉&#xff1f; 接口自动化异常处理方法&#xff1a; pytest去掉warning提示 可以再pytest,ini文件设置过滤掉告警信息

静态网页设计——奥迪官网(HTML+CSS+JavaScript)

前言 声明&#xff1a;该文章只是做技术分享&#xff0c;若侵权请联系我删除。&#xff01;&#xff01; 使用技术&#xff1a;HTMLCSSJS 主要内容&#xff1a;①网站栏目设计说明。 网站为奥迪官网&#xff0c;由奥迪首页、奥迪车型&#xff08;具体车型介绍&#xff09;、…

8K超高清应用:输电线网智慧巡检提升巡视效率

电力安全关系国计民生&#xff0c;是国家安全的重要保障&#xff0c;因此确保电力线路系统的安全运行至关重要。电力线路系统整体分为三大板块&#xff1a;输电线路、变电站和配电线路。然而&#xff0c;由于自然灾害、人为破坏等因素影响&#xff0c;这三大板块的设备很容易发…

BERT(从理论到实践): Bidirectional Encoder Representations from Transformers【3】

这是本系列文章中的第3弹,请确保你已经读过并了解之前文章所讲的内容,因为对于已经解释过的概念或API,本文不会再赘述。 本文要利用BERT实现一个“垃圾邮件分类”的任务,这也是NLP中一个很常见的任务:Text Classification。我们的实验环境仍然是Python3+Tensorflow/Keras…

ubuntu 安装 anaconda

ubuntu 安装 anaconda 下载 wget https://repo.anaconda.com/archive/Anaconda3-2023.09-0-Linux-x86_64.sh安装 bash Anaconda3-2023.09-0-Linux-x86_64.sh2.1 回车继续 2.2 许可协议 输入 q 退出阅读许可协议 2.3 输入 yes 接受 许可协议 2.4 设置 anaconda 安装位置 如不需…

kubernetes(二)创建集群

kubernetes&#xff08;一&#xff09;概述与架构 云原生实战 语雀 官网 Kubernetes 文档 | Kubernetes 更新&#xff1a;移除 Dockershim 的常见问题 | Kubernetes B站课程&#xff1a;https://www.bilibili.com/video/BV13Q4y1C7hS/?p26 安装版本说明&#xff1a; 视频教程…

【驱动序列】C#获取电脑硬件基本组合以及基础信息

大家好&#xff0c;我是全栈小5&#xff0c;欢迎阅读《小5讲堂之知识点实践序列》文章。 这是2024年第7篇文章&#xff0c;此篇文章是C#知识点实践序列文章&#xff0c;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不对之处望指正&#xff01; 要开发一款驱动小助手&…

基于springboot+vue网吧管理系统(程序+数据库+文档)

&#x1f345;点赞收藏关注 → 私信领取本源代码、数据库&#x1f345; 本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目希望你能有所收获&#xff0c;少走一些弯路。&#x1f345;关注我不迷路&#x1f345;摘 要 随着信息技术和网络技术的…

leetcode2397. 被列覆盖的最多行数

目录 题目 思路 解题方法 题目 https://leetcode.cn/problems/maximum-rows-covered-by-columns/description/ 给你一个下标从 0 开始、大小为 m x n 的二进制矩阵 matrix &#xff1b;另给你一个整数 numSelect&#xff0c;表示你必须从 matrix 中选择的 不同 列的数量。 …

scipy.signal 详解

scipy.signal 详解 scipy.signal 模块是 SciPy 库中用于信号处理的重要模块。它提供了许多用于数字信号处理、滤波、频谱分析、傅里叶变换、卷积等操作的函数和工具。以下是一些 scipy.signal 模块中常用的函数和功能&#xff1a; 滤波函数 FIR/IIR 滤波器设计 &#xff1a; …

如何解决大语言模型的幻觉问题

如何解决大模型的「幻觉」问题&#xff1f; 什么是大模型「幻觉」 在人类生活中&#xff0c;幻觉表示虚假的但是我们分辨不清楚的事物&#xff0c;在大语言模型中&#xff0c;[幻觉]即代表模型生成的虚假的文本&#xff0c;这中情况很容易导致一些错误的发生 造成大模型「幻觉…

VMware17安装Centos 7.9

1.下载VMware17&#xff0c;下载 VMware Workstation Pro | CN 没有注册码&#xff0c;某多&#xff0c;某宝2元子买一个&#xff1b; 2.下载centos7.9镜像&#xff0c; 3.选择稍后安装操作系统 (如果选择安装程序光盘映像文件&#xff0c;则会按照最小系统自动安装) 4.选择…

电商快递运费对账教程

电商快递运费对账&#xff0c;有没有什么方法&#xff0c;能够事半功倍&#xff1f;回答这个问题之前&#xff0c;我们先来看看电商卖家们&#xff0c;为什么需要对账&#xff1f;基本上都是怎么对账的&#xff1f; 我们都知道&#xff0c;电商与快递行业存在着一定的“共生关…

vue-打包

打包的作用 说明&#xff1a;vue脚手架只是开发过程中&#xff0c;协助开发的工具&#xff0c;当真正开发完了>脚手架不参与上线 打包的作用&#xff1a; 1&#xff09;将多个文件压缩合并成一个文件 2&#xff09;语法降级 3&#xff09;less sass ts语法解析 打包后…

图像分割实战-系列教程8:unet医学细胞分割实战6(医学数据集、图像分割、语义分割、unet网络、代码逐行解读)

&#x1f341;&#x1f341;&#x1f341;图像分割实战-系列教程 总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Pycharm中进行 本篇文章配套的代码资源已经上传 unet医学细胞分割实战1 unet医学细胞分割实战2 unet医学细胞分割实战3 unet医学细胞分割实战4 unet…

麒麟KYLINOS操作系统上扩容系统盘

原文链接&#xff1a;麒麟KYLINOS操作系统上扩容系统盘 hello&#xff0c;大家好啊&#xff01;继之前我们讨论了如何在统信UOS上扩容数据盘之后&#xff0c;今天我要给大家带来的是在麒麟KYLINOS操作系统上扩容系统盘与数据盘的方法。随着数据的不断增长&#xff0c;系统盘或数…

Nginx 的SSL证书配置

目录 1.申请域名&#xff0c;证书下载 2.准备站点源代码 3.修改nginx 对应网站的配置文件 4.修改 host 文件 http协议访问的网站默认会显示不安全&#xff0c;因为数据默认是明文传输的 https是httpssl&#xff0c;ssl是加密协议&#xff0c;通过证书来进行加密的&#xff…

promethues grafana 安装和使用

文章目录 1、promethues安装2、node-exporter安装3、grafana安装4、配置promethues监控node节点5、grafana操作外传 Docker 镜像下载地址&#xff1a; https://hub.docker.com 比较好的hub.docker.com///-- https://hub.docker.com/u/bitnami grafana监控面板&#xff1a;https…

使用Docker方式安装Artifactory

1、安装前环境准备 首先要关闭防火墙&#xff0c;关闭Selinux&#xff0c;准备好安装好的docker。以下安装版本&#xff1a;7.19.10 ##关闭防火墙&#xff0c;并设置开机自关闭 systemctl stop firewalld.service systemctl disable firewalld.service ##查看防火墙状态 sy…