【MySQL】数据处理函数

news2024/11/15 9:57:04

只有当你开始相信自己时,你才拥有真正的人生。——《洛奇》


前言:

大家好,我是爱打拳的程序猿。今天给大家展示是数据处理函数的用法,分为单行处理函数和分组函数。数据处理函数主要是为了更方便解决数据的各种问题。文章以代码和还原窗口的方式展现给大家,一起来看看吧。


目录

1、单行处理函数

数据处理函数是什么?

1.1创建一个薪资表

1.2LOWER和UPPER函数

1.3SUBSTER函数

1.4LENGTH函数

1.5CONCAT函数

1.6TRIM函数

1.7ROUND函数

2、分组函数

2.1COUNT函数

2.2SUM函数

2.3AVG函数

2.4MAX函数

2.5MIN函数

3、分组函数注意事项

3.1注意1

3.2注意2

3.3注意3

3.4注意4


1、单行处理函数

数据处理函数是什么?

数据处理函数是用来更方便的计算表中某一字段数据。它分为单行处理函数和多行处理函数。单行处理函数的特点是一个输入对应一个输出。多行处理函数是多个输入对应一个输出。


1.1创建一个薪资表

首先,我们创建一个简易的薪资表,往后的所有函数也是通过这张表来讲解。

mysql> create table Pay(
    -> id int,
    -> name varchar(10),
    -> salary decimal(10,3),
    -> bonus decimal(10,3),
    -> holiday int
    -> );
Query OK, 0 rows affected (0.02 sec)

mysql> insert into Pay (id,name,salary,bonus,holiday) values
    -> (1001,'Bob',2345.435,800,5),
    -> (1002,'Tom',3454.534,500.435,2),
    -> (1003,'Mimi',5534.565,900,10),
    -> (1004,'Boss',10000,888.666,20);
    -> (1005,'Ggg',2454,300,null);
Query OK, 5 rows affected (0.00 sec)
Records: 5  Duplicates: 0  Warnings: 0

mysql> select * from Pay;
+------+------+-----------+---------+---------+
| id   | name | salary    | bonus   | holiday |
+------+------+-----------+---------+---------+
| 1001 | Bob  |  2345.435 | 800.000 |       5 |
| 1002 | Tom  |  3454.534 | 500.435 |       2 |
| 1003 | Mimi |  5534.565 | 900.000 |      10 |
| 1004 | Boss | 10000.000 | 888.666 |      20 |
| 1005 | Ggg  |  2454.000 | 300.000 |    NULL |
+------+------+-----------+---------+---------+
5 rows in set (0.00 sec)

窗口显示:

 


单行处理函处理有这些:

函数名描述
LOWER转换小写
UPPER转换大写
SUBSTER字符串长度
LENGTH取长度
TRIM去空格
STR_TO_DATE将字符串转换为日期
DATE_FROMAT格式化日期
FORMAT设置千分位
ROUND四舍五入
RAND()生成随机数
IFNULL()可以将NULL转换成一个具体值
CONCAT函数进行字符串的拼接

1.2LOWER和UPPER函数

lower函数的用法就是将一串字符种的大写转换成小写,如果字符本身就是小写则不管。语法为:select lower(字段) from 表名;

我要将薪资表的name中大写都改为小写:

mysql> select lower(name) from Pay;
+-------------+
| lower(name) |
+-------------+
| bob         |
| tom         |
| mimi        |
| boss        |
| ggg         |
+-------------+
5 rows in set (0.00 sec)

窗口显示:

upper函数的用法就是将一串字符种的小写转换成大写,如果字符本身就是大写则不管。语法为:select upper(字段) from 表名;

我要将薪资表的name中小写都改为大写:

mysql> select upper(name) from Pay;
+-------------+
| upper(name) |
+-------------+
| BOB         |
| TOM         |
| MIMI        |
| BOSS        |
| GGG         |
+-------------+
5 rows in set (0.00 sec)

窗口显示:


1.3SUBSTER函数

substr是截取字符串从某一下标到另一下标的字段,起始下标为1终止下标根据你的需求来定。格式为:select substr(字段,前下标,后下标) from 表名;

比如我要找到薪资表name的第一个字符,也就是员工的姓:

mysql> select substr(name,1,1) name from Pay;
+------+
| name |
+------+
| B    |
| T    |
| M    |
| B    |
| G    |
+------+
5 rows in set (0.00 sec)

窗口显示:

如果我们要找姓名为B的人,怎么查找呢。有两种方法:

1.使用模糊查询like

mysql> select name from Pay where name like'B%';
+------+
| name |
+------+
| Bob  |
| Boss |
+------+
2 rows in set (0.00 sec)

2.使用substr查询

mysql> select name from Pay where substr(name,1,1)='B';
+------+
| name |
+------+
| Bob  |
| Boss |
+------+
2 rows in set (0.00 sec)

两种方式窗口显示都一样:


1.4LENGTH函数

length跟java的length一样都是求长度,语法为select length(字段) from 表名;

求薪资表中所有name的长度:

mysql> select length(name) count from Pay;
+-------+
| count |
+-------+
|     3 |
|     3 |
|     4 |
|     4 |
|     3 |
+-------+
5 rows in set (0.01 sec)

窗口显示:


1.5CONCAT函数

concat函数的用法就是合并两个字符串,语法:select concat(字段1,字段2) from 表名;

将薪资表中的id和salary连接起来:

mysql> select concat(id,salary) connect from Pay;
+---------------+
| connect       |
+---------------+
| 10012345.435  |
| 10023454.534  |
| 10035534.565  |
| 100410000.000 |
| 10052454.000  |
+---------------+
5 rows in set (0.00 sec)

窗口显示:


1.6TRIM函数

trim是去掉一个字符串前后的括号,比如我不小心在一个字段前后打上了几个空格trim函数会自动去掉这些空格:

mysql> select * from Pay where name=trim('  Boss   ');
+------+------+-----------+---------+---------+
| id   | name | salary    | bonus   | holiday |
+------+------+-----------+---------+---------+
| 1004 | Boss | 10000.000 | 888.666 |      20 |
+------+------+-----------+---------+---------+
1 row in set (0.00 sec)

窗口显示:


1.7ROUND函数

round函数是用来做四舍五入操作的,当然你可以规定保留几位小数。语法为:select 字段 round(字段,保留位数) from 表名;

比如我要使工资保留一位小数并且四舍五入:

mysql> select name,round(salary,1) salary from Pay;
+------+---------+
| name | salary  |
+------+---------+
| Bob  |  2345.4 |
| Tom  |  3454.5 |
| Mimi |  5534.6 |
| Boss | 10000.0 |
| Ggg  |  2454.0 |
+------+---------+
5 rows in set (0.00 sec)

窗口显示:

 

保留多位小数,他只会对最后一位小数位进行四舍五入,最后一位前的小数不进行四舍五入。如我要保留两位小数:

mysql> select name,round(salary,2) salary from Pay;
+------+----------+
| name | salary   |
+------+----------+
| Bob  |  2345.44 |
| Tom  |  3454.53 |
| Mimi |  5534.57 |
| Boss | 10000.00 |
| Ggg  |  2454.00 |
+------+----------+
5 rows in set (0.00 sec)

窗口显示:


2、分组函数

分组函数/聚合函数/多行处理函数

函数名描述
COUNT计数
SUM求和
AVG平均值
MAX最大值
MIN最小值

分组函数在使用时必须先分组再使用,如果是对整张表使用则默认这张表为一组。多行处理函数是多个输入对应一个输出。因为分组查询比较简单,我就直接讲解语法,然后实例演示。


2.1COUNT函数

count函数是用来计数的,统计某一个字段出现的次数,语法:select count(字段) from 表名;

求薪资表中员工的个数:

mysql> select count(id) count from Pay;
+-------+
| count |
+-------+
|     5 |
+-------+
1 row in set (0.00 sec)

窗口显示:


2.2SUM函数

sum函数是用来求和的,计算某一字段数据的总和,语法:select sum(字段) from 表名;

求薪资表中所有员工工资总和:

mysql> select sum(salary) salsum from Pay;
+-----------+
| salsum    |
+-----------+
| 23788.534 |
+-----------+
1 row in set (0.00 sec)

窗口显示:


2.3AVG函数

avg函数是求某一字段内数据的平均值,语法:select avg(字段) from 表名;

求薪资表中员工平均工资:

mysql> select avg(salary) salavg from Pay;
+--------------+
| salavg       |
+--------------+
| 4757.7068000 |
+--------------+
1 row in set (0.00 sec)

窗口显示:


2.4MAX函数

max函数是求某一字段内数据的最大值。语法:select max(字段) from 表名;

求薪资表中工资最高为多少:

mysql> select max(salary) salmax from Pay;
+-----------+
| salmax    |
+-----------+
| 10000.000 |
+-----------+
1 row in set (0.00 sec)

窗口显示:


2.5MIN函数

min函数是求某一字段内数据的最小值。语法:select min(字段) from 表名;

求薪资表中工资最低为多少:

mysql> select min(salary) salmin from Pay;
+----------+
| salmin   |
+----------+
| 2345.435 |
+----------+
1 row in set (0.00 sec)

窗口显示:


3、分组函数注意事项

3.1注意1

在mysql数据库中,在运算时如果某一数据为NULL。则最后的结果一定是空,但在分组函数进行运算时会自动忽略NULL。

 我们可以看到Pay表中假期(holiday)字段有一空,那么我对它进行求和会不会造成结果为空呢?

mysql> select sum(holiday) test from Pay;
+------+
| test |
+------+
|   37 |
+------+
1 row in set (0.00 sec)

窗口显示:

我们发现并没有结果为NULL,证实了上面那句话,分组函数运算时忽略NULL。


3.2注意2

分组函数中的count(*)和count(某字段)有什么区别?

count(*)是统计该字段所有数据的计数包括NULL,而count(字段)是统计除NULL以外数据的计数。

mysql> select count(*) from Pay;
+----------+
| count(*) |
+----------+
|        5 |
+----------+
1 row in set (0.00 sec)

mysql> select count(holiday) from Pay;
+----------------+
| count(holiday) |
+----------------+
|              4 |
+----------------+
1 row in set (0.00 sec)

窗口显示:

 因此,count(*)是通常是用来统计行数的,count(字段)是用来计数某一字段除NULL以外的数据。


3.3注意3

分组函数不得直接使用在where子句中!会提示使用了无效的分组函数 。

如用条件查询找工资最大值:

mysql> select name,salary salmax from Pay where salary>min(salary);
ERROR 1111 (HY000): Invalid use of group function

窗口显示:


3.4注意4

分组函数可以联合使用,比如我要将员工薪资的最小值,最大值,平均值,总和,员工个数显示出来: 

mysql> select min(salary) salmin,max(salary) salmax,avg(salary) salavg,sum(salary) salsum,count(*) salcou from Pay;
+----------+-----------+--------------+-----------+--------+
| salmin   | salmax    | salavg       | salsum    | salcou |
+----------+-----------+--------------+-----------+--------+
| 2345.435 | 10000.000 | 4757.7068000 | 23788.534 |      5 |
+----------+-----------+--------------+-----------+--------+
1 row in set (0.00 sec)

窗口显示:


 本期博客到这里就结束了,码文不易还请三连一波,感谢你的阅读。

 Never Give Up

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

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

相关文章

2023年Unity UI教程

2023年Unity UI教程 Unity 新 UI 系统 UI 工具包的完整概述 课程英文名:Modern Unity UI with UI Toolkit 此视频教程共10.0小时,中英双语字幕,画质清晰无水印,源码附件全 下载地址 课程编号:336 百度网盘地址&am…

SSM框架-获取容器的方式

9 容器 9.1 获取容器 记载类路径下的容器所在的配置文件,也就是之前用的 public class App2 {public static void main(String[] args) {ApplicationContext ctx new ClassPathXmlApplicationContext("applicationContext.xml");BookDao bookDao (BookDao) ctx.…

liunx 部署 kkfileview文件预览 以及解决https访问

kkfileview gitee地址 https://gitee.com/kekingcn/file-online-preview 1.下载office组件 wget https://kkfileview.keking.cn/LibreOffice_7.1.4_Linux_x86-64_rpm.tar.gz tar -zxvf LibreOffice_7.1.4_Linux_x86-64_rpm.tar.gz cd LibreOffice_7.1.4.2_Linux_x86-64_rpm/R…

TensorRT推理手写数字分类(一)

系列文章目录 (一)使用pytorch搭建模型并训练 文章目录系列文章目录前言一、网络搭建1.LeNet网络结构2.pytorch代码二、网络训练1.pytorch代码2.结果展示三、保存和加载模型1.保存整个网络2.保存网络中的参数总结前言 为了学习一下使用TensorRT进行推理…

硬核!Github星标79.4K的阿里强推Java面试参考指南到底有多强?

谈到Java面试,相信大家第一时间脑子里想到的词肯定是金三银四,金九银十。好像大家的潜意识里做Java开发的都得在这个时候才能出去面试,跳槽成功率才高!但LZ不这么认为,LZ觉得我们做技术的一生中会遇到很多大大小小的面…

Java并发编程—如何写好代码?链式调用该怎么玩?

目录 一、案例说明 二、原生方式代码流程 三、链式调用代码流程 四、链式调用手搓的方式: 五、总结: 在上一篇博客https://blog.csdn.net/qq_52545155/article/details/128212148?spm1001.2014.3001.5501,博主在写商城统计商品价格的时…

mybatis中其他数据源也使用XML进行操作(SqlSessionFactory.openSession(Connection connection)方法)

文章目录1. 前言2. 先说结论3. 例子1. 准备数据2. 思考过程3. 结论1. 前言 当前在使用springbootmybatis的时候,通常会先在配置文件中配置好数据源,并在Mapper.xml文件编写好相关SQL,使用mybatis进行对数据库进行所谓的crud操作。 有时候会出…

nginx代理https妈妈级手册

目录 背景说明 相关地址 https证书生成 nginx安装及配置 结果展示​编辑 背景说明 为了保证传输加密、访问安全,我们采用nginx服务器将http服务代理为https。所需材料:openssl(用来生成证书)、http服务、nginx自身。 相关地址…

C/C++第三方库zeromq、log4cpp交叉编译、本地安装ubuntu180.04

一、zeromq的编译安装 1)ubuntu下命令 apt-get install libzmq3-dev不推荐这种方式,因为很可能安装的版本并不是最新的; 2)自己编译安装(推荐) 地址:https://github.com/zeromq/libzmq/relea…

设计模式--装饰者模式

文章目录前言一、未使用设计模式二、装饰者模式1.定义2.角色三、应用场景四、优缺点优缺前言 晓子(咖啡店员),来一杯美式,加点威士忌和砂糖。 抱歉啊,猫。收银系统还没有你说的组合,要不换一个&#x1f60…

React 的调度系统 Scheduler

大家好,我是前端西瓜哥。今天来学习 React 的调度系统 Scheduler。 React 版本为 18.2.0 React 使用了全新的 Fiber 架构,将原本需要一次性递归找出所有的改变,并一次性更新真实 DOM 的流程,改成通过时间分片,先分成一…

nnUnet测试

https://github.com/MIC-DKFZ/nnUNet nnUnet要在Windows上跑起来有点麻烦,主要是项目路径的问题,我目前测试了2分类遥感数据(其实只要是二分类都行,无所谓什么数据),我这里说难是因为我没有安装&#xff0…

【SQL】MVCC 多版本并发控制

MVCC多版本并发控制快照读与当前读隔离级别隐藏字段,undo log 版本链隐藏字段trx_id版本链read view举例说明read committed(读已提交)隔离级别下repeatable read(可重复读)隔离级别下innodb如何解决幻读总结并发问题的…

LaTex使用技巧9:argmin / argmax下标写法

记录两种写法 1.arg⁡max⁡θ\mathop{\arg\max}\limits_{\theta}θargmax​的写法 写法1: $\mathop{\arg\max}\limits_{\theta}$ 写法2: $\sideset{}{}{\arg\max}_{\theta}^{} $ 2.arg⁡min⁡θ\mathop{\arg\min}\limits_{\theta}θargmin​的写法 写法…

STL常用生成算法和集合算法(20221207)

STL的常用算法 概述&#xff1a; 算法主要是由头文件<algorithm> <functional> <numeric> 组成。 <algorithm>是所有STL头文件中最大的一个&#xff0c;涉及比较、交换、查找、遍历等等&#xff1b; <functional>定义了一些模板类&#xff0…

做一个公司网站大概要多少钱?

做一个公司网站大概要多少钱&#xff0c;很多公司在做网站之前可能已经简单了解过费用&#xff0c;但是费用差距都会比较大&#xff0c;为什么的呢&#xff0c;因为一般都是受到制作方式因素的影响。下面给大家说说不同的方式做一个公司网站大概要多少钱。 一、自己/团队做公司…

SQLyog —— 图形化工具使用

SQLyog下载链接&#xff1a; 点击跳转 在这一篇内容MySQL数据库 —— 常用语句当中讲到关于MySQL数据库命令的基本使用&#xff0c;这一篇是关于SQLyog数据库图形化工具的内容&#xff0c;先进行安装演示后在通过SQLyog进行操作数据库&#xff1a; SQLyog 安装 下载完成之后双击…

pageoffice在线打开word文件加盖电子印章

一、加盖印章的 js 方法 js方法 二、常见使用场景 1、常规盖章。弹出用户名、密码输入框&#xff0c;选择对应印章。 点击盖章按钮弹出用户名密码登录框&#xff0c;登录以后显示选择电子印章。 document.getElementById("PageOfficeCtrl1").ZoomSeal.AddSeal(…

Python模块pathlib操作文件和目录操作总结

前言 目前大家常用的对于文件和操作的操作使用 os.path 较多&#xff0c;比如 获取当前路径os.getcwd()&#xff0c;判断文件路径是否存在os.path.exists(folder) 等等。 在Python3.4开始&#xff0c;官方提供了 pathlib 面向对象的文件系统路径&#xff0c;核心的点在于 面向…

chatGPT代码写的有点好啊,程序员要失业了?

AI神器ChatGPT 火了。 能直接生成代码、会自动修复bug、在线问诊、模仿莎士比亚风格写作……各种话题都能hold住&#xff0c;它就是OpenAI刚刚推出的——ChatGPT。 有脑洞大开的网友甚至用它来设计游戏&#xff1a;先用ChatGPT生成游戏设定&#xff0c;再用Midjourney出图&…