SQL - 函数

1. 操作类函数

这一类函数针对数据结构,表格进行筛选操作

1.1 GROUP BY

根据某个单一列中属性或者多个列对结果集进行分组

sql 复制代码
SELECT column1, SUM(column2)
FROM table
GROUP BY column1;

上述代码将所选择列进行column1中的属性分组,作为每一行的索引,统计出column1对应的属性中column2的总和

使用GROUP BY分组之后条件筛选需要使用HAVING而不是WHERE

1.2 HAVING

HAVING的功能与WHERE很像,都是对于数据进行筛选

但WHERE无法筛选GROUP BY分组之后的数据,所以我们需要用到HAVING

sql 复制代码
SELECT column1 , SUM(column2)
FROM Table
GROUP BY column1
HAVING SUM(column2) <>= xxx;

1.3 EXISTS

用于判断子句是否存在

sql 复制代码
SELECT column1
FROM table
WHERE EXISTS/NOT EXISTS
(SELECT column FROM table WHERE condition);

2. Aggregate函数

这一类函数计算从列中所取得的值,返回一个单一值

2.1 AVG()

返回列数据的平均值

sql 复制代码
SELECT AVG(column1) FROM xxx;

2.2 COUNT

返回列数据数据的总数,不包含null

sql 复制代码
SELECT COUNT(column1) FROM xxx;
SELECT COUNT(DISTINCT column2) AS new_column FROM;

2.3 LIMIT

通过限制,我们可以按照表格某种顺序选取第一个/最后一个出现的元素

注:跟在排序之后

sql 复制代码
SELECT column1 FROM table
ORDER BY column1 DESC/ASCE
LIMIT 1;

使用LIMIT去限制第几个

2.4 MAX

返回列的最大值

sql 复制代码
SELECT MAX(COLUMN1) FROM table;

2.5 MIN

返回列的最小值

sql 复制代码
SELECT MIN(COLUMN1) FROM table;

2.6 SUM

返回数值列数据的总和

sql 复制代码
SELECT SUM(column1) FROM table;

3. Saclar函数

这一类函数会基于输入的值返回一个单一值

常见于字符操作,文本操作中

3.1 UCASE

将字段的值转换为大写

sql 复制代码
SELECT UCASE(column1) FROM table;

3.2 LCASE

将字段的值转换为小写

sql 复制代码
SELECT LCASE(column1) FROM table;

3.3 MID

从文本字段中提取字符

sql 复制代码
SELECT MID(column,start,length) FROM table1;

|--------|-----------|
| column | 提取的列 |
| start | 需要提取的起始位置 |
| length | 字段的长度 |

3.4 LEN

返回某一列各个数据长度

sql 复制代码
SELECT name, LEN(url) AS LEN_url FROM table;

3.5 ROUND

将数据四舍五入,decimal表示小数点后几位

sql 复制代码
SELECT ROUND(column1,decimals) FROM table;

3.6 NOW

返回当前系统的日期时间

sql 复制代码
SELECT NOW() AS now_time FROM table;

3.7 FORMAT

对于数据内容进行格式化

sql 复制代码
SELECT FORMAT(column,format) FROM table;

|--------|--------------|
| column | 需要进行格式化的字段,列 |
| format | 格式化规定的格式 |

相关推荐
阿里云大数据AI技术4 小时前
大数据公有云市场第一,阿里云占比47%!
大数据
RestCloud4 小时前
揭秘 CDC 技术:让数据库同步快人一步
数据库·api
得物技术7 小时前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql
Lx3528 小时前
Hadoop容错机制深度解析:保障作业稳定运行
大数据·hadoop
可涵不会debug11 小时前
【IoTDB】时序数据库选型指南:工业大数据场景下的技术突围
数据库·时序数据库
ByteBlossom11 小时前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试
麦兜*11 小时前
MongoDB Atlas 云数据库实战:从零搭建全球多节点集群
java·数据库·spring boot·mongodb·spring·spring cloud
Slaughter信仰11 小时前
深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)第十章知识点问答(10题)
java·jvm·数据库
麦兜*11 小时前
MongoDB 在物联网(IoT)中的应用:海量时序数据处理方案
java·数据库·spring boot·物联网·mongodb·spring