SQL函数
分为两种:
- Aggregate 函数
- Scalar 函数
Aggregate
AVG() - 返回平均值
COUNT() - 返回行数
FIRST() - 返回第一个记录的值
LAST() - 返回最后一个记录的值
MAX() - 返回最大值
MIN() - 返回最小值
SUM() - 返回总和
Scalar
UCASE() - 将某个字段转换为大写
LCASE() - 将某个字段转换为小写
MID() - 从某个文本字段提取字符
LEN() - 返回某个文本字段的长度
ROUND() - 对某个数值字段进行指定小数位数的四舍五入
NOW() - 返回当前的系统日期和时间
FORMAT() - 格式化某个字段的显示方式
语法样例
1、
SELECT AVG(column_name) FROM table_name
注:有一些语法,如first,大多数数据库都不支持。
2、GROUP BY 语句用于结合聚合函数,根据一个或多个列对结果集进行分组。
SELECT column_name, aggregate_function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name;
例:SELECT site_id, SUM(access_log.count) AS nums
FROM access_log GROUP BY site_id;
3、HAVING 子句
在 SQL 中增加 HAVING 子句原因是,WHERE 关键字无法与聚合函数一起使用。
HAVING 子句可以让我们筛选分组后的各组数据。
SELECT column_name, aggregate_function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name
HAVING aggregate_function(column_name) operator value;
例:SELECT Websites.name, Websites.url, SUM(access_log.count) AS nums FROM (access_log INNER JOIN Websites ON access_log.site_id=Websites.id) GROUP BY Websites.name HAVING SUM(access_log.count) > 200;
4、SQL MID() 语法
SELECT MID(column_name,start[,length]) FROM table_name;
- column_name 必需。要提取字符的字段。
- start 必需。规定开始位置(起始值是 1)。
- length 可选。要返回的字符数。如果省略,则 MID() 函数返回剩余文本。
5、SQL ROUND() 语法
SELECT ROUND(column_name,decimals) FROM table_name;
- column_name 必需。要舍入的字段。
- decimals 必需。规定要返回的小数位数。