myql中常用上级路径包含本身

mysql自定义函数获取上级的路径实例

sql 复制代码
CREATE  FUNCTION `querydept_path_name`(depetId VARCHAR(255)) RETURNS varchar(255) CHARSET utf8
BEGIN
DECLARE sTempPath VARCHAR(255);
DECLARE sTempChd VARCHAR(255);
DECLARE sFullPath VARCHAR(255);
 
SET sTempChd = depetId;
SET sFullPath ='';
SET sTempPath ='';
 
WHILE (sTempChd <> '' ) DO
select ifnull((SELECT dept_name FROM dept_info  WHERE id = sTempChd),'') INTO sTempPath;
SET sFullPath = CONCAT(sFullPath,sTempPath,'/');
select ifnull((SELECT parent_id FROM dept_info  WHERE id = sTempChd),'')  INTO sTempChd;

END WHILE;
 
RETURN sFullPath;
END

函数创建失败错误信息

创建函数时报错信息

sql 复制代码
[Err] 1418 - This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)

解决办法

解决方法

  1. 在mysql数据库中执行以下语句 (临时生效,重启后失效)
sql 复制代码
set global log_bin_trust_function_creators=TRUE;

或者

sql 复制代码
set global log_bin_trust_function_creators=1;
  1. 在配置文件/etc/my.cnf[mysqld]或者my-default.ini文件中配置
sql 复制代码
[mysqld]
log_bin_trust_function_creators=1

测试函数路径

默认路径为逆序

sql 复制代码
select querydept_path_name('10011')

路径正序

sql 复制代码
select REVERSE(querydept_path_name('10011'))
相关推荐
Bert.Cai1 小时前
MySQL CURTIME()函数详解
数据库·mysql
Bert.Cai1 小时前
MySQL CURDATE()函数详解
数据库·mysql
NGSI vimp1 小时前
MySQL|MySQL 中 `DATE_FORMAT()` 函数的使用
数据库·mysql
秋91 小时前
MySQL8.0.46 与 MySQL8.4.9:跨越代际的深度差异解析与升级全指南
mysql
HAWK eoni1 小时前
Mysql 驱动程序
数据库·mysql
xxjj998a1 小时前
Laravel4.x核心特性全解析
android·mysql·laravel
何中应2 小时前
CentOS 7安装、卸载MySQL数据库(二)
数据库·mysql·centos
梁萌2 小时前
mysql使用事件做日志表数据转移
数据库·mysql
lThE ANDE2 小时前
MySQL中的TRUNCATE TABLE命令
数据库·mysql
STER labo3 小时前
mysql配置环境变量——(‘mysql‘ 不是内部或外部命令,也不是可运行的程序 或批处理文件解决办法)
数据库·mysql·adb