MySQL之CRUD,函数与union使用

目录

一.CRUD 

 1.1.SELECT(查询)

1.2.INSERT(新增)

1.3.UPDATE(修改)

1.4.DELETE(删除)

二.函数

2.1.常见函数

2.1.1.字符函数

 2.1.2.数字函数

2.1.3.日期函数

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<表达式>是可选项,如果选择该项,将限定查询数据必须满足该查询条件。
  • `GROUPBY<字段>,该子句告诉MySQL如何显示查询出来的数据,并按照指定的字段分组。
  • `[ORDERBY<字段>,该子句告诉MySQL按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序。
  • `[LIMIT[<offset>,]<row count]`,该子句告诉MySQL每次显示查询出来的数据条数。

1.2.INSERT(新增)

概念:使用INSERT语句向数据库已有的表中插入一行或者多行元组数据。

语法: 

INSERT...VALUES语句:

INSERTINTO<表名>[<列名1>[,……<列名n>]]
VALUES(值1)[...,(值n)];

INSERT...SET语句:

INSERTINTO<表名>
SET<列名1>=<值1>
<列名2>=<值2>,

含义:

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

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

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

1.3.UPDATE(修改)

语法: 

UPDATE<表名>SET字段1=值1[,字段2=值2..][WHERE子句]

[ORDERBY子句][LIMIT子句]

含义:

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

1.4.DELETE(删除)

语法:

DELETEFROM<表名>[WHERE子句][ORDERBY子句][LIMIT子句]

含义:

-`<表名>:指定要删除数据的表名。

—-`ORDERBY`子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。

-`WHERE`子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。

-`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,926,2)45.93
截断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_FORMAT(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) 查询同时存在"01"课程和"02"课程的情况

SELECT

t3.*,

(CASEWHENt1.cid='01'THENt1.scoreEND)语文,

(CASEWHENt2.cid='02'THENt2.scoreEND)数学

FROM

(SELECT*FROM t_mysql_scoresc WHERE sc.cid='01')t1,

(SELECT*FROM t_mysql_scoresc WHERE sc.cid='02')t2,

t_mysql_student t3

WHERE

t1.sid =t2.sid

AND t1.sid =t3.sid

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

SELECT a.id,a.title,a.content,a.canyuze,a.liexize,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

when0then'取消会议'

when1then'新建'

when2then'待审核

when3then'驳回'

when4then'待开

when5then'进行中'

when6then'开启投票'

else'结束会议'end

)as meetingState

,a.seatPic,a.remark,a.auditor,c. name`as auditorName

FROM t_oa_meeting_info a

inner join t_oa_userb on a.zhuchiren = b.id

left JOIN t oa user con a.auditor=c.id where 1=1;

2.3.聚合函数

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

三.union与union all

概念UNION:用于合并两个或多个SELECT语句的结果集,并去除重复的行。
UNIONALL:用于合并两个或多个SELECT语句的结果集,包括重复的行。
语法UNION:将多个SELECT语句放在一起,并使用UNION关键字将它们连接起来。每个SELECT语句的列数、列名和数据类型必须相同。
UNIONALL:将多个SELECT语句放在一起,并使用UNIONALL关键字将它们连接起来。每个SELECT语句的列数、列名和数据类型可以不同。
专业词解释UNION:UNION操作符执行去除重复行的操作,它通过对所有的结果集进行排序和比较来实现。
UNIONALL:UNIONALL操作符不执行去除重复行的操作,它直接将所有的结果集合并在一起。
使用场景UNION:当需要合并多个查询结果,并且不希望出现重复行时,可以使用UNION操作符。它适用于数据需要去重的情况。
UNIONALL:当需要合并多个查询结果,包括重复行时,可以使用UNIONALL操作符。它适用于不需要去重的情况,或者在已经确定结果不会有重复行的情况下。
实例全列初始数据SELECT*from t_oa_meeting_info where id>=1 andid<=8; SELECT*from t_oa_meeting_info where id>=6 andid<=10;
UNION

SELECT*from t_oa_meeting_info where id>=1 andid<=8

UNION
SELECT*from t_oa_meeting__info where id>=6 andid<=10;

678只出现了1次
UNION allSELECT*from t_oa_meeting_info where id>=1 andid<=8
UNION all 
SELECT*from t_oa_meeting_info where id>=6 andid<=10;
 
678重复出现
单列初始数据 SELECT id from t_oa_meeting_info where id>=1 andid<=8;
SELECT id from t_oa_meetin_info where id>=6 andid<=10;
UNION

SELECT id from t_oa_meeting_info where id>=1 andid<=8

UNION
SELECT id from t_oa_meeting_info where id>=6 andid<=10

 678只出现了1次
UNION all

SELECT id from t_oa_meeting_info where id>=1 andid<=8

UNION all 
SELECT id from t_oa_meeting_info where id>=6 andid<=10;

678重复出现
结论所谓去重并不需要所有列相同

四.思维导图


           好啦今天就到这里了哦!!!希望能帮到你哦!!!

 

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

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

相关文章

Linux 安装 MySQL

一、安装 MySQL 的准备工作 1. 查看系统版本 cat /etc/redhat-release2. 查看系统是否已经安装过 MySQL 查看是否安装了 MySQL rpm -qa | grep mysql查看是否有安装 mariadb&#xff0c;该软件与 MySQL 数据库有冲突&#xff0c;需要手动卸载 # 如果是 CentOS7 可以检测出…

Scene Creator

场景创建器是一个方便、易于使用的编辑工具&#xff0c;旨在简化创建新场景的过程。使用场景创建器&#xff0c;您可以选择一个模板场景&#xff0c;定义一个目录来存储您的场景&#xff0c;并在需要时自动将新场景添加到构建中。 下载&#xff1a; ​​Unity资源商店链接 资…

vue3安装vue-tools

https://github.com/vuejs/devtools/tree/v6.5.0/packages 打开浏览器扩展程序 这个文件直接拖进扩展程序

【源码分析】 Calcite 处理流程详解:calcite架构、处理流程以及就一个运行示例进行源码分析

文章目录 一. Calcite整体架构二. Calcite处理流程三. 处理流程样例说明1. 样例demo1.1. 样例数据1.2. 使用calcite 2. 流程源码分析Step1: SQL 解析阶段&#xff08;SQL–>SqlNode&#xff09;Step2: SqlNode 验证&#xff08;SqlNode–>SqlNode&#xff09;1. 注册元数…

整理的6个Linux运维脚本

整理的6个Linux运维脚本 1、统计/etc/passwd 中能登录的用户&#xff0c;并将对应在/etc/shadow 中第二列密码提取2、查看当前连接到本机的远程IP地址3、检测本机当前用户是否为超级管理员&#xff08;root&#xff09;4、检查指定目录下是否存在对应文件5、查找 Linux 系统中的…

在线的omniplan甘特图制作工具

在线的omniplan甘特图制作工具 快捷键 按住空格键 可以拖动画布Tab 将选中的任务右缩进&#xff08;设置为子任务&#xff09;Shift Tab 将选中的任务提升一级&#xff08;取消子任务&#xff09;按住Shift可以选择多个任务按住Ctrl 或者 Mac 的 command 可以选择多个任务按…

Redis专题(持续更新)

02-VIP-Redis持久化、主从与哨兵架构详解 文章目录 02-VIP-Redis持久化、主从与哨兵架构详解正文Redis哨兵高可用架构redis哨兵架构搭建步骤&#xff1a;sentinel集群都启动完毕后&#xff0c;会将哨兵集群的元数据信息写入所有sentinel的配置文件里去(追加在文件的最下面)&…

基于深度学习的PCB板缺陷检测系统(含UI界面、yolov8、Python代码、数据集)

项目介绍 项目中所用到的算法模型和数据集等信息如下&#xff1a; 算法模型&#xff1a;     yolov8 yolov8主要包含以下几种创新&#xff1a;         1. 添加注意力机制&#xff08;SE、CBAM等&#xff09;         2. 修改可变形卷积&#xff08;DySnake-主干c…

pod探针

Pod进阶&#xff1a; 探针* Poststart Prestop pod的声明周期开始&#xff1a; k8s的pod重启策略&#xff1a; Always deployment的yaml三种模式都可以&#xff0c;不论正常退出还是非正常退出都重启 OnFailure:只有状态码非零才会重启&#xff0c;正常退出事不重启的 …

(读书笔记)网络是如何连接的

1.1 生成 HTTP 请求消息 浏览器是一个具备多种客户端功能的综合性客户端软件,因此它需要 一些东西来判断应该使用其中哪种功能来访问相应的数据,而各种不同的 URL(Uniform Resource Locator,统一资源定位符。) 就是用来干这个的,比如访问 Web 服务器时用“http:”,而访…

2024.1.4 Spark Core ,RDD ,算子

目录 一 . RDD(弹性分布式数据集) 二 . RDD的五个特性 三 .RDD的五大特点 四 . 算子 五 . 分区算子 ,重分区算子 , 聚合算子 ,关联算子 分区算子: 重分区算子 聚合算子 关联算子: 一 . RDD(弹性分布式数据集) Resilent弹性 Distrbuted分布式 Dataset数据集…

vue day5

1、自定义指令 2、v-loading指令封装&#xff08;蒙层&#xff09; 3、插槽 默认插槽 使用组件时&#xff0c;传入具体标签内容 4、插槽 后备内容&#xff08;默认值&#xff09; 5、具名插槽 6、作用域插槽 7、案例 App.vue&#xff1a; <template><d…

ubuntu桥接方式上网

vmvare:VMware Workstation 17 Pro ubuntu: Ubuntu 14.04.6 LTS window10 下面是我的电脑配置 下面是ubuntu虚拟机的配置 vi /etc/network/interfaces 下面的gateway就是window -ipconfig 截图里的默认网关 auto lo iface lo inet loopbackauto eth0 iface eth0 inet stat…

前端实战第一期:悬浮动画

悬浮动画 像这样的悬浮动画该怎么做&#xff0c;让我们按照以下步骤完成 步骤&#xff1a; 先把HTML内容做起来&#xff0c;用button属性创建一个按钮&#xff0c;按钮内写上悬浮效果 <button classbtn>悬浮动画</button>在style标签内设置样式,先设置盒子大小&…

Linux 命令tail

命令作用 tail 命令用于显示文件的末尾内容&#xff0c;默认显示文件的最后 10 行。通常情况下&#xff0c;tail 命令用于实时查看动态日志文件&#xff0c;可以使用 -f 参数跟踪文件内容的变化。 语法 tail [选项] [文件名] 参数 以 log.txt 为例演示参数效果 -n -linesK…

大数据开发的专业术语

&#x1f339;作者主页&#xff1a;青花锁 &#x1f339;简介&#xff1a;Java领域优质创作者&#x1f3c6;、Java微服务架构公号作者&#x1f604; &#x1f339;简历模板、学习资料、面试题库、技术互助 &#x1f339;文末获取联系方式 &#x1f4dd; 系列专栏目录 [Java项…

【LeetCode:11. 盛最多水的容器 | 双指针】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

阶段十-分布式-任务调度

第一章 定时任务概述 在项目中开发定时任务应该一种比较常见的需求&#xff0c;在 Java 中开发定时任务主要有三种解决方案&#xff1a;一是使用JDK 自带的 Timer&#xff0c;二是使用 Spring Task&#xff0c;三是使用第三方组件 Quartz Timer 是 JDK 自带的定时任务工具,其…

感知与认知的碰撞,大模型时代的智能文档处理范式

目录 0 写在前面1 GPT4-V&#xff1a;拓宽文档认知边界2 大语言模型的文档感知缺陷3 大一统文档图像处理范式3.1 像素级OCR任务3.2 OCR大一统模型3.3 长文档理解与应用 4 总结抽奖福利 0 写在前面 由中国图象图形学学会青年工作委员会发起的第十九届中国图象图形学学会青年科学…

ElasticSearch使用Grafana监控服务状态-Docker版

文章目录 版本信息构建docker-compose.yml参数说明 创建Prometheus配置文件启动验证配置Grafana导入监控模板模板说明 参考资料 版本信息 ElasticSearch&#xff1a;7.14.2 elasticsearch_exporter&#xff1a;1.7.0&#xff08;latest&#xff09; 下载地址&#xff1a;http…