①MySQL的函数——聚合函数、数学函数、字符串函数、日期函数

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: MySQL的函数——聚合函数、数学函数、字符串函数、日期函数

在MySQL中,为了提高代码重用性和隐藏实现细节,MySQL提供了很多函数。函数可以理解为别人封装好的模板代码。


在MySQL中,聚合函数主要由:count,sum,min,max,avg,这些简单的组成,但是仍然有许多的聚合函数需要我们自己去了解和掌握,下面我们将详细的介绍MySQL一些基本的函数,旨在解决我们日常的一些的业务场景问题。


聚合函数

group_concat

group_concat()函数首先根据group by指定的列进行分组,并且用分隔符分隔,将同一个分组中的值连接起来,返回一个字符串结果。


group_concat([distinct] 字段名 [order by 排序字段 asc/desc] [separator '分隔符'])

它和我们最初学习的group by是有所区别的;这里的分组是将一列里面的值进行分组,然后放在跳一行的表中。


说明:


 (1)使用distinct可以排除重复值;


 (2)如果需要对结果中的值进行排序,可以使用order by子句;


 (3)separator是一个字符串值,默认为逗号。、


准备数据集

create table emp(
    emp_id int primary key auto_increment comment '编号',
    emp_name char(20) not null default '' comment '姓名',
    salary decimal(10,2) not null default 0 comment '工资',
    department char(20) not null default '' comment '部门'
);
insert into emp(emp_name,salary,department) 
values('张晶晶',5000,'财务部'),('王飞飞',5800,'财务部'),('赵刚',6200,'财务部'),('刘小贝',5700,'人事部'),
('王大鹏',6700,'人事部'),('张小斐',5200,'人事部'),('刘云云',7500,'销售部'),('刘云鹏',7200,'销售部'),
('刘云鹏',7800,'销售部');

image.png


那么肯定有的小伙伴,对该函数有所疑问,为什么要使用该函数呢,这种函数应用场景在哪里呢?


应用场景:王老板此时需要看每个部门的人员是那些,此时的你应该怎么做,学了这个函数之后你就可以一行代码解决。它与group by联合使用的效果比较好,例如下面还可以指定分隔符,便于我们自己查看。


-- 指定分隔符合并 
select department,group_concat(emp_name separator '-' ) from emp group by department;

image.png

我们还可以指定排序方式,在这里我们可以按照他们的薪资水平进行展示,那么也显示该函数的一个功能,这里面不单单可以对某一列进行字段分组,还可以对另外一列进行排序


-- 指定排序方式和分隔符 
select department,group_concat(emp_name order by salary desc separator ';' ) from emp group by department;



image.png

ABS(X) 取绝对值

-- ABS(X)
-- 修改标准的字段,使其变成负数
UPDATE emp SET salary=-salary  WHERE emp_name ='王大鹏';
SELECT salary from emp WHERE emp_name='王大鹏';
SELECT ABS(salary) from emp WHERE emp_name='王大鹏';

CEIL(X) 返回大于或者等于X的最小整数

select ceil(1.7) #2


image.png

那么比如0.7,那么就是1


floor(X)返回小于或者等于X的最小整数

-- FLOOR(X)
SELECT FLOOR(1.7)

image.png


GREATEST(expr1 ...) 返回列表中的最大值

返回以下数字列表中的最大值:

SELECT GREATEST(3, 12, 34, 8, 25); -- 34

返回以下字符串列表中的最大值:

SELECT GREATEST("Google", "Runoob", "Apple");   -- Runoob


LEAST(expr1...) 返回列表中的最小值

返回以下数字列表中的最小值:

SELECT LEAST(3, 12, 34, 8, 25); -- 3

返回以下字符串列表中的最小值:

SELECT LEAST("Google", "Runoob", "Apple");   -- Apple


常见的数学函数

image.png

image.png




相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
关系型数据库 MySQL 索引
936. 【mysql】locate函数
936. 【mysql】locate函数
22 2
|
1月前
|
SQL 关系型数据库 MySQL
927. 【mysql】coalesce 函数
927. 【mysql】coalesce 函数
23 3
|
1月前
|
关系型数据库 MySQL
926.【mysql】 date 函数
926.【mysql】 date 函数
67 3
|
1月前
|
关系型数据库 MySQL
925. 【mysql】convert 函数
925. 【mysql】convert 函数
23 3
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL 数据库】2、MySQL 的数据控制语言、函数和约束
【MySQL 数据库】2、MySQL 的数据控制语言、函数和约束
31 0
|
11天前
|
SQL 关系型数据库 MySQL
DQL语言之常见函数(mysql)
DQL语言之常见函数(mysql)
|
18天前
|
SQL 关系型数据库 MySQL
mysql多表查询、函数查询
mysql多表查询、函数查询
|
1月前
|
关系型数据库 MySQL 数据库
【mysql】—— 函数的基本介绍
【mysql】—— 函数的基本介绍
|
1月前
|
关系型数据库 MySQL
922.【mysql】if 函数
922.【mysql】if 函数
19 3
|
1月前
|
关系型数据库 MySQL 数据处理
Mysql基础第十四天,使用数据处理函数
Mysql基础第十四天,使用数据处理函数
60 0