MySQL之、CRUD、函数及union查询(实施必会)

文章目录

  • 前言
  • 一、CRUD
    • 1.1SELECT(查询)
    • 1.2INSERT(新增)
    • 1.3UPDATE(修改)
    • 1.4DELETE(删除)
  • 二、函数
    • 2.1常见函数
      • 2.1.1字符函数
      • 2.1.2数字函数
      • 2.1.3日期函数
    • 2.2流程控制函数(重点)
    • 2.3聚合函数
  • 三、union与union all
  • 思维导图:

前言

本篇博主给大家带来MySQL之、CRUD、常见函数及union查询,希望能够帮助到大家

一、CRUD

1.1SELECT(查询)

  • 概念:查询数据是指从数据库中根据需求,使用不同的查询方式来获取不同的数据,是使用频率最高、最重要的操作
  • 语法:
    SELECT
    {*|<字段名>}
    [FROM<表1>,<表2>.....
    [WHERE<表达式>
    [GROUP BY <group by definition>
    [HAVING <expression> [{<operator><expression>}...]]
    [ORDE BY <order by definition>]
    [LIMIT[<offset>]<row count>]]
  • 含义:
    1.{*|<字段列名>}包含星号通配符的字段列表,表示所要查询字段的名称。
    2.<表1>,<表2> 表1和表2表示查询数据的来源,可以是单个或者多个
    3.WHERE<表达式>是可选项,如果选择该项,将限定查询数据必须满足该查询条件
    4.GROUP BY<字段>,该句子告诉MySQL如何显示查询出来的数据,并按照指定的字段分组
    5.[ORDER BY<字段>],该句子告诉MySQL按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序
    6.[LIMIT[],] 该句子告诉MySQL每次显示查询出来的数据条数

1.2INSERT(新增)

  • 概念:使用INSERT 语句向数据库已有的表中插入一行或者多行元组数据
  • 语法:
    INSERT...VALUES语句:INSERT INTO<表名>[<列名1>[....<列名n>]] VALUES(值1)[...(值n)]
    INSERT....SET语句:INSERT INTO<表名>SET<列名1>=<值1>,<列名2>=<值2>
  • 含义:
    1.<表名>:指定被操作的表名
    2.<列名>:指定需要插入数据的列名。诺向表中的所有列插入数据,则全部的列名均可以省略,直接采用INSERT<表名>VALUES(…)即可
    3.VALUES或VALUE子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应。
  • 由于INSERT 语句的两种形式可以看出
  • 使用INSERT…VALUES语句可以向表中插入一行数据,也可以插入多行数据
  • 使用INSERT…SET语句可以指定插入其行中每列的值,也可以指定部分列的值
  • INSERT …SELECT语句向表中插入其他表的数据
  • 采用INSERT…SET语句可以向表中插入部分列的值,这种方式更为灵活
  • INSERT …VALUES语句可以一次插入多条数据

1.3UPDATE(修改)

  • 语法:
    UPDATE<表名>SET字段1=值1[,字段2=值2....][WHERE子句][ORDER BY 子句][LIMIT 子句]
  • 含义:
    1.<表名>:用于指定要更新的表名称
    2.SET子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可以用关键字DEFAULT表示列值
    3.WHERE 子句:可选项。用于限定表中的行被修改的次序
    4.LIMIT子句:可选项。用于限定被修改的行数。

1.4DELETE(删除)

  • 语法:
    DELETE FROM<表名>[WHERE子句][ORDER BY 子句][LIMIT 子句]
  • 含义:
    1.<表名>:指定要删除数据的表名
    2.ORDER BY子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除
    3.WHERE 子句:可选项。表示删除操作限定删除任务。诺省略该子句,则代表删除该表中的所有行
    4.LIMIT 子句:可选项。用于告知服务器在控制命令被返回到客户端被删除行的最大值

二、函数

2.1常见函数

2.1.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','b','m')-----amcd

2.1.2数字函数

  • 四舍五入:ROUND(45.936,2)---45.92
  • 截断:TRUNC(45.926,2)----45.92
  • 求余:MOD(1600,300)----100

2.1.3日期函数

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

2.2流程控制函数(重点)

  • 语法:CASE expr WHEN comparison_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.canyuze,a.liexize,a.zhuchiren,b.'name',a.location,DATE_FROMMAT(a.startTime,'%Y-%m-%d %H:%i:%s')as startTime,
DATE_FROMAT(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_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操作符。它适用于不需要去重的情况,或者已经确定结果不会有重复行的情况下
  • 实例:
    ①全列:
    初始数据:
    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:
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
结果678只出现了1次

UNION all:

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
结果678重复出现

②单列:
初始数据:
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:

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
结果678只出现了1次

UNION all:

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
结果678重复出现
  • ③结论:所谓去重并不需要所有列相同

思维导图:

在这里插入图片描述

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

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

相关文章

搜维尔科技:ART光学跟踪系统在工业VR/AR领域的应用

ART公司成立于1999年&#xff0c;拥有38万员工遍布全球&#xff0c;ART一直致力于红外线光学跟踪系统的研发与生产&#xff0c;并将先进的科技应用于产品研发&#xff0c;产品制造&#xff0c;市场营销&#xff0c;产品销售以及优秀的客户支持。主要向客户提供高端的虚拟现实跟…

MySQL Enterprise版本各系统安装包下载

一、官方下载地址 oracle下载地址 https://edelivery.oracle.com/osdc/faces/SoftwareDelivery 使用oracle账号登录进去 Category选择Download Package(下载安装包)&#xff0c;搜索栏输入mysql Enterprise关键字点search进行搜索。选项结果第一个MySQL Enterprise Edition&a…

JAVA的引用与C++的指针有什么区别

JAVA的引用与C的指针有什么区别 1. Java值类型与引用类型1.1 变量初始化1.2 变量赋值1.3 函数传参 2. Java数据存储方式2.1 Java局部变量&&Java方法参数2.2 Java数组类型引用和对象2.3 String类型数据 3. Java引用类型3.1 强引用3.2 软引用3.3 弱引用3.4 虚引用 4. JAV…

MySQL8.0安装教程

Mysql安装教程 1.Mysql下载 进入官网https://www.mysql.com/进行下载&#xff1a; 2.Mysql安装 双击文件进行安装&#xff0c;选择默认安装方式&#xff1a; 这里列出了五种安装类型&#xff1a; Developer Default&#xff1a;默认安装类型&#xff1b;Server only&#x…

在Ubuntu22.04上部署Stable Diffusion

在AI绘画软件领域Stable-Diffusion&#xff08;简称SD&#xff09;在开源领域绝对是不二之选&#xff0c;他的插件方式可以让此软件具有更多的功能&#xff0c;开发者社群为此提供了大量免费高质量的外接预训练模型&#xff08;fine-tune&#xff09;和插件&#xff0c;并持续维…

Linkage Mapper 各工具参数详解——Barrier Mapper

【小白一学就会无需其他教程】此文档用于解析使用Linkage Mapper 各输入输出参数详情以及可能的影响&#xff0c;并介绍了如何解释模型输出结果和输出参数&#xff0c;适合刚入手的人。篇幅很长很啰嗦&#xff0c;是因为每个参数都解释的万分细致。 从以下链接中获取内容&#…

Linux文件fd剖析

学习之前&#xff0c;首先要认识什么是文件&#xff1f; 空文件也是要在内存中占据空间的&#xff0c;因为它还有属性数据。文件 属性 内容文件操作 对内容 对属性 或者对内容和属性的操作标定一个文件的时候&#xff0c;必须使用&#xff1a;路径文件名&#xff0c;文件具…

交换机03_基本配置

一、思科设备的命令行基础 1、进入设备的命令行界面 设备支持命令行 去查看设备上的接口&#xff0c;是否有console口需要有console线 右击此电脑设备管理器需要通过超级终端软件进行连接&#xff0c;如putt、secret CRT、xshell等软件 &#xff08;1&#xff09;思科模拟器…

Python从入门到精通之元类

系列 Python从入门到精通之安装与快速入门-CSDN博客 Python从入门到精通之基本数据类型和变量-CSDN博客 Python从入门到精通之集合&#xff08;List列表、Tuple元组、Dict字典、Set&#xff09;-CSDN博客 Python从入门到精通之条件语句、循环语句和函数-CSDN博客 Python从…

02、Kafka ------ 配置 Kafka 集群

目录 配置 Kafka 集群配置步骤启动各Kafka节点 配置 Kafka 集群 启动命令&#xff1a; 1、启动 zookeeper 服务器端 小黑窗输入命令&#xff1a; zkServer 2、启动 zookeeper 的命令行客户端工具 &#xff08;这个只是用来看连接的节点信息&#xff0c;不启动也没关系&#…

Python从入门到网络爬虫(面向对象详解)

前言 Python从设计之初就已经是一门面向对象的语言&#xff0c;正因为如此&#xff0c;在Python中创建一个类和对象是很容易的。本章节我们将详细介绍Python的面向对象编程。如果你以前没有接触过面向对象的编程语言&#xff0c;那你可能需要先了解一些面向对象语言的一些基本…

HTML5+CSS3⑥——CSS三大特性、表格、列表

CSS特性 继承性 层叠性 优先级 叠加计算规则 表格 表格结构标签 合并单元格 列表 无序列表 有序列表 定义列表

Spring中基于注解的IOC配置项目举例详解

文章目录 Spring中基于注解的IOC配置项目举例详解1、创建如下结构的Spring项目pom.xmldao层service层application.xmllog4j.properties 2、用于创建对象的常用注解2.1、Controller或Controller("user")声明bean,且id"user"2.2、Service或用Service("u…

2024年的诸多跨年演讲,为什么觉得像是鸡汤?

时光如白驹过隙匆匆而已&#xff0c;转瞬间已来到2024年。伴随着新的一年的到来&#xff0c;一些互联网大佬如罗振宇、吴晓波等纷纷直播演讲&#xff0c;分享各自的思考和感悟。值不值得听呢&#xff1f;为什么有时候觉得是鸡汤&#xff1f;这里分析下可能的原因。 罗振宇的“做…

基于EMD-SpEn(样本熵)联合小波阈值去噪

代码原理 基于 EMD-SpEn&#xff08;样本熵&#xff09;联合小波阈值去噪方法是一种用于信号降噪的信号处理方法&#xff0c;它结合了经验模态分解 (EMD)、样本熵 (SpEn) 和小波阈值处理技术。 首先&#xff0c;使用 EMD 将原始信号分解为一组称为经验模态函数 (IMFs) 的信号…

VUE3跳转页面时 定时器未清除解决

一,问题 1、在vue中使用setTimeout定时器的时候&#xff0c;可能会遇到关不掉的情况&#xff0c;会存在明明已经在beforeDestroy和destroyed中设置了定时器清除了&#xff0c;但是有时候没生效&#xff0c;定时器还会继续执行。 2、在这里需要说一下setTimeout的使用场景&…

新能源汽车@2023/24:卷价格、拼智能与生态战

【潮汐商业评论/原创】 2023年末尾&#xff0c;受到大众广泛热议的小米汽车发布会“姗姗来迟”&#xff0c;也为“乱战”中的2023新能源汽车市场画上了一个句号。 然而&#xff0c;在雷军整整三个小时看似平和的演讲与技术讲解中&#xff0c;实则在电机、智驾、智舱等核心技术…

java基础之java8新特性-默认方法

目录 1.默认方法 jdk8之前的接口 jdk8的接口 默认方法的用途 1.默认方法 jdk8之前的接口 在jdk8之前接口&#xff08;interface&#xff09;中可以定义变量和方法&#xff0c;变量必须是public&#xff0c;static&#xff0c;final的&#xff1b;方法必须是public&#xf…

初识对抗生成网络(GAN)

在研究语义通信的时候&#xff0c;发现解码端很多都是用GAN或基于GAN来完成的。带着对GAN的好奇&#xff0c;对GAN进行了一个初步学习。这篇文章介绍一下和GAN相关的一些常识吧~   本文围绕以下几个内容展开&#xff1a;     1.什么是GAN&#xff1f;     2.为什么要…

独立看门狗与窗口看门狗

一、简介 STM32F10xxx内置两个看门狗&#xff0c;提供了更高的安全性、时间的精确性和使用的灵活性。两个看门狗设备(独立看门狗和窗口看门狗)可用来检测和解决由软件错误引起的故障&#xff1b;当计数器达到给定的超时值时&#xff0c;触发一个中断(仅适用于窗口型看门狗)或产…