mysql 系统函数类型有哪些

mysql 系统函数类型有哪些,第1张

1、数学函数

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


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8481065.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-16
下一篇 2023-04-16

发表评论

登录后才能评论

评论列表(0条)

保存