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 | 格式化规定的格式 |

相关推荐
m0_702036532 分钟前
html标签如何提升可访问性_aria-label与title区别【指南】
jvm·数据库·python
城事漫游Molly4 分钟前
统计研究路线图:PPDAC问题解决循环
大数据·人工智能·论文笔记·科研统计
会编程的土豆5 分钟前
Gin 核心概念速记
数据库·后端·gin·goland
ㄟ留恋さ寂寞8 分钟前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】
jvm·数据库·python
iiiiyu38 分钟前
⾯向对象和集合编程题
java·大数据·开发语言·数据结构·编程语言
Donk_671 小时前
iSCSI 服务器
运维·服务器·数据库
Lyon198505281 小时前
【握剑之手】——《文字定律》随笔
大数据·人工智能·ai写作
打码人的日常分享1 小时前
大模型及智能体安全风险防范与治理策略(PPT)
运维·网络·数据库·安全·云计算·制造
Elastic 中国社区官方博客1 小时前
Kubernetes 可观测性:用于更安全 EKS 故障排查的 MCP 专家 agents
大数据·elasticsearch·搜索引擎·云原生·容器·kubernetes·全文检索
hughnz1 小时前
钻井“自动化”的终点就是钻井自主化的起点
运维·数据库·python