美文网首页
mysql函数

mysql函数

作者: 蛋皮皮652 | 来源:发表于2020-12-24 21:17 被阅读0次

在实际开发中我们会遇到比较繁琐的业务需求,假如我们在java程序中实现,我们要写不少的代码,这时候如果我们用mysql的自定义函数,就可以轻松的解决这些问题,但是我们使用mysql自定义的函数或者存储过程,在写代码的时候直接调用,就会很方便,这也就是dba所要做的事情。

我遇到的一个应用场景就是在一个部门用户树下,最后一级是用户,没有children,用户的信息需要存两个部门,一个是这个人所在的部门,另一个是这个人所在的最顶级的部门,也就是我们常说的老祖宗,干掉老祖宗,整个家族也就gg了,于是我就想使用mysql的自定义函数来实现找到老祖宗,就算查询的时候也方便,于是我就创建了如下的函数。

实现的是每个父节点的拼接从而找到老祖宗为止。

但是我在保存函数的时候提示了his function has none of DETERMINISTIC, NO SQL...

解决方法:

解决办法也有两种, 第一种是在创建子程序(存储过程、函数、触发器)时,声明为DETERMINISTIC或NO SQL与READS SQL DATA中的一个, 例如: CREATE DEFINER = CURRENT_USER PROCEDURE `NewProc`()     DETERMINISTIC BEGIN #Routine body goes here... END;;

第二种是信任子程序的创建者,禁止创建、修改子程序时对SUPER权限的要求,设置log_bin_trust_routine_creators全局系统变量为1。

设置方法有三种:

1.在客户端上执行SET GLOBAL log_bin_trust_function_creators = 1;

2.MySQL启动时,加上--log-bin-trust-function-creators选贤,参数设置为1

3.在MySQL配置文件my.ini或my.cnf中的[mysqld]段上加log-bin-trust-function-creators=1

我使用的是第一种,简单方便。

我的表结构如下:

接下来调用函数来看结果。

传入子节点,从而找到老祖宗为止。是不是很方便呢?喜欢请关注“蛋皮皮”公众号。

相关文章

网友评论

      本文标题:mysql函数

      本文链接:https://www.haomeiwen.com/subject/evrvnktx.html