2、聚合函数(常用于GROUP BY从句的SELECT查询中)、
3、字符串函数
4、日期和时间函数
5、加密函数
6、控制流函数
7、格式化函数
8、类型转化函数
9、系统信息函数
以上就是mysql 中常用的一些函数类型,如果不清楚具体的用法,可以参照相关教程,比如:http://www.maiziedu.com/course/371/
MySQL 8.0 新增了 GROUPING() 函数,用来理清 GROUP BY with rollup 子句检索后所产生的每个分组汇总结果。 grouping 可用在分组列,having 子句以及 order by 子句。
GROUPING() 函数用来返回每个分组是否为 ROLLUP 结果,是为 1 否为 0。从结果中,很容易就能区分哪些 NULL 是正常记录,哪些是 ROLLUP 的结果。
GROUPING() 函数不仅仅是针对单个字段来统计汇总值,还可以针对多个字段。
此时会发现,GROUPING() 函数对多个字段结果并非只有 1 和 0,还有一个值为 3。在 GROUPING() 函数包含多个参数时,按照以下方式来返回结果:
GROUPING(r1,r2) 等价于 GROUPING(r2) + GROUPING(r1) <<1
GROUPING(r1,r2,r3,...) 等价于 GROUPING(r3) + GROUPING(r2) <<1 + GROUPING(r1) <<2
以此类推
GROUPING 语句还可以用在 HAVING 子句里,比如用 GROUPING 子句来过滤掉非 ROLLUP 的结果。
mysql是可以使用递归函数的,如下例子:mysql树查询,sql递归函数
select cateID from goodscategory where FIND_IN_SET(cateID ,getGoodsChildLst('43242'))
CREATE FUNCTION `getGoodsChildLst`(rootId INT)
RETURNS varchar(1000)
BEGIN
DECLARE sTemp VARCHAR(1000)
DECLARE sTempChd VARCHAR(1000)
SET sTemp = '$'
SET sTempChd =cast(rootId as CHAR)
WHILE sTempChd is not null DO
SET sTemp = concat(sTemp,',',sTempChd)
SELECT group_concat(cateID) INTO sTempChd FROM goodscategory where FIND_IN_SET(parentCateID,sTempChd)>0
END WHILE
RETURN sTemp
END
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)