MySQL经常会用到查询树结构数据,这里专门收集整了一篇。

  • 构建函数

构建树查询函数:查询父级节点函数

-- 在mysql中完成节点下的所有节点或节点上的所有父节点的查询
-- 根据传入id查询所有父节点的id
DROP FUNCTION IF EXISTS `getParList`;
delimiter //
CREATE FUNCTION `getParList`(rootId INT)
RETURNS varchar(255)
BEGIN
DECLARE sTemp VARCHAR(255); -- 设置变量
DECLARE sTempPar VARCHAR(255);
SET sTemp = '';
SET sTempPar =rootId; #循环递归
while sTempPar is not null DO
#判断是否是第一个,不加的话第一个会为空
IF sTemp != '' THEN
SET sTemp = concat(sTemp,',',sTempPar);
ELSE
SET sTemp = sTempPar;
END IF;
SET sTemp = concat(sTemp,',',sTempPar);
SELECT group_concat(pid) INTO sTempPar FROM china_region where pid<>id and FIND_IN_SET(id,sTempPar)>0;
END WHILE;
RETURN sTemp;
END
//

-- id是前面表中的,110105为子级id

select * from china_region where FIND_IN_SET(id,getParList(110105));

构建树查询函数:查询子级节点函数

-- 根据传入id查询所有子节点的id
DROP FUNCTION IF EXISTS `getChildList`;
delimiter //
CREATE FUNCTION `getChildList`(rootId INT)
RETURNS varchar(255)
BEGIN
DECLARE sTemp VARCHAR(255);
DECLARE sTempChd VARCHAR(255);
SET sTemp = '';
SET sTempChd =rootId;
WHILE sTempChd is not null DO
SET sTemp = concat(sTemp,',',sTempChd);
SELECT group_concat(id) INTO sTempChd FROM china_region where FIND_IN_SET(pid,sTempChd)>0;
END WHILE;
RETURN sTemp;
END
//

-- id是前面表中的,110000为父级id

select * from china_region where FIND_IN_SET(id,getChildList(110000));

-- 批量更新

update china_region
set sort_number = CASE `level`
when 0 then 0
when 1 then 100
when 2 then 200
when 3 then 300
end,
label = case `level`
when 1 then 'value1'
when 2 then 'value2'
when 3 then 'value3'
ELSE 'others'
end
where id >= 100000 and id <120000 ;

-- 清空 sort_number 和 label 列

UPDATE china_region set sort_number=NULL, label=NULL;

构建循环查询函数:循环查询函数

-- 循环查询
delimiter $$
drop function if exists loops;
create function loops(num int) returns varchar(255)
begin
declare i int default 110101;
declare result varchar(255) default '';
lpl:loop -- lp1 为循环体名称 LOOP 为关键字
if result != '' then
set result=concat(result,',',i);
else
set result=i;
end if;
update china_region set sort_number=i where id=i;
set i=i + 1;
if i>num
then
leave lpl; -- 离开循环体
end if;
end loop lpl; -- 结束循环
return result;
end $$
delimiter;

-- 循环查询序号+1

select loops(110117);

构建拼接函数:循环拼接函数

-- 循环拼接组合
delimiter $$
drop function if exists fun_addStr;
create function fun_addStr(str1 varchar(32),str2 varchar(32),num int) returns varchar(200)
begin
declare i int default 1;
declare result varchar(200) default '';
set result=str1;
myloop:loop
set i=i+1;
set result=concat(result,str2);
if i>num
then
leave myloop;
end if;
end loop myloop;
return result;
end $$
delimiter;

-- 循环拼接组合

select fun_addStr('字符串一','字符串二',3);
  • 存储过程

-- 查询数据库中的存储过程和函数

select `name` from mysql.proc where db = 'testdb' and `type` = 'PROCEDURE';   -- 存储过程
select * from mysql.proc where db = 'testdb' and `type` = 'PROCEDURE' and name='xx';
select `name` from mysql.proc where db = 'testdb' and `type` = 'FUNCTION'; -- 函数
show procedure status;    -- 存储过程
show function status; -- 函数

-- 查看存储过程或函数的创建代码

show create procedure proc_name;
show create function func_name;

-- 查看视图

SELECT * from information_schema.VIEWS; -- 视图
SELECT * from information_schema.TABLES; -- 表

-- 查看触发器
SHOW TRIGGERS [FROM db_name] [LIKE expr];

SELECT * FROM information_schema.`TRIGGERS` T WHERE trigger_name='mytrigger';

作者:Jason Zeng 于 2020-06-14
博客:http://www.cnblogs.com/zengming/ 
GItHub:https://github.com/lovelifeming
严正声明:
1.由于本博客部分资源来自互联网,版权均归原作者所有。转载的目的是用于学术交流与讨论学习,将不对任何资源负法律责任。
2.若无意中侵犯到您的版权利益,请来信联系我,我会在收到信息后会尽快给予处理!
3.所有资源内容仅供学习交流之用,请勿用作商业用途,谢谢。
4.如有转发请注明出处,来源于http://www.cnblogs.com/zengming/ ,谢谢合作。

MySQL 查询树结构、循环查询、查看函数、视图、存储过程的更多相关文章

  1. 【软件实施面试】MySQL和Oracle联合查询以及聚合函数面试总结

    软件实施面试系列文章第二弹,MySQL和Oracle联合查询以及聚合函数的面试总结.放眼望去全是MySQL,就不能来点Oracle吗?之前面过不少公司,也做过不少笔试题,现在已经很少做笔试题了.你肚子 ...

  2. 【MySQL】-2 函数、分组、子查询、联合查询

    函数 Mysql的函数特性没有SQL可移植性强. 大多数情况下支持的函数: 处理文本串的函数: RTrim():处理列值右边的空格 LTrim():处理列值左边的空格   Trim():处理列值的左右 ...

  3. sql:sql server,MySQL,PostgreSQL的表,视图,存储过程结构查询

    sql server 2005: --SQL SERVER 2005 生成代码需要知道的SQL语句 use LibrarySystem --查询当前数据库所有表和其的主键字段,字段类型,长度,是否为空 ...

  4. MYSQL - 外键、约束、多表查询、子查询、视图、事务

    MYSQL - 外键.约束.多表查询.子查询.视图.事务 关系 创建成绩表scores,结构如下 id 学生 科目 成绩 思考:学生列应该存什么信息呢? 答:学生列的数据不是在这里新建的,而应该从学生 ...

  5. SQL Server -- 回忆笔记(四):case函数,索引,子查询,分页查询,视图,存储过程

    SQL Server知识点回忆篇(四):case函数,索引,子查询,分页查询,视图,存储过程 1. CASE函数(相当于C#中的Switch) then '未成年人' else '成年人' end f ...

  6. 【mysql】 mysql 子查询、联合查询、模糊查询、排序、聚合函数、分组----------语法

    第二章 mysql 一.模糊查询 like 1. 字段 like '河北省%' %代表任何N个字符 2 字段 like '河北省____' _代表任意1个字符 二.IN 语法:SELECT 字段列1, ...

  7. Mysql优化之Explain查询计划查看

    我们经常说到mysql优化,优化中一种常见的方式就是对于经常查询的字段创建索引.那么mysql中有哪些索引类型呢? 一.索引分类1.普通索引:即一个索引只包含单个列,一个表可以有多个单列索引 2.唯一 ...

  8. 在论坛中出现的比较难的sql问题:32(row_number函数+子查询 sql循环取差值)

    原文:在论坛中出现的比较难的sql问题:32(row_number函数+子查询 sql循环取差值) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路. sql循环取差值,该怎 ...

  9. SQLserver查询作业、视图、函数、存储过程中的关键字

    一.查询视图.函数.存储过程中的关键字 SELECT a.name,a.[type],b.[definition] FROM sys.all_objects a,sys.sql_modules b W ...

  10. (四)MySQL条件查询(通配符、模糊查询)、排序查询、分组查询(单行、分组函数)

    一.条件查询 1.含义:前面学的基础查询可以查询一个或多个字段,如果需要的数据仅仅是其中的某一行或多行就用到了条件查询. 2.语法:(序号表示语句执行顺序) SELECT 字段名 ③ FROM 表名 ...

随机推荐

  1. Loadrunner11压测场景时最多跑5000个Vuser的问题解决办法

    当我在用Loadrunner11压测场景时,设置Start Vusers是10000个.但实际运行是发现大约跑到5000个左右,后面的基本都是异常.如图: 查看Vusers运行详情: Error... ...

  2. 基于FATE的可验证秘密分享算法详解及应用场景分享:学习

    内容来自"光大科技-基于FATE的可验证秘密分享算法详解及应用场景分享" 理论 基于Shamir的秘密共享方案,通过多项式插值实现. 加入可验证功能,即发送多项式系数的模数给对方作 ...

  3. 异常try-catch-finally与存储和JSON.parse

    捕获异常 捕获异常:处理可能出现的异常,当发生错误后,我们对它进行处理,不让程序崩溃. 异常处理 try-catch-finally try{ // 可能出现异常的:代码1 }catch(err){ ...

  4. openbox每日开机自动切换网络壁纸

    目的 利用bing的每日一图, 每天切换壁纸 开干 联网后下载图片 利用networkmanage启动后执行脚本 netafter.sh 文件地址: /etc/NetworkManager/dispa ...

  5. overflow秒解外边距合并以及浮动导致的元素塌陷问题

    外边距导致的合并问题: 1 处于一上一下位置的两个块级元素 在同时各自设置了上下边距时,二者间的外边距通常以 数值较大的一个作为两者间的外边距 而不是简单的数值相加 .box2{ width: 100 ...

  6. 以数字守护汉字!天翼云TeleDB数据库获GB 18030最高级别认证!

    近日,由工信部电子工业标准化研究院主办的GB 18030<信息技术 中文编码字符集>应用推广大会暨"汉字守护计划"成果发布会召开,工信部信发司.中央网信办信息化局.教育 ...

  7. 解密prompt系列48. DeepSeek R1 & Kimi 1.5长思维链 - RL Scaling

    春节前DeepSeek R1和Kimi1.5炸翻天了,之前大家推测的O1的实现路径,多数都集中在MCTS推理优化,以及STaR等样本自优化方案等等,结果DeepSeek和Kiim直接出手揭示了reas ...

  8. Trae初体验

    前情 自从AI IDE面世以来,网络上到处流传程序员要失业了,小白也能轻松完成程序开发了,某某0基础靠AI上架了苹果应用,平时工作也有偶尔用用AI工具的我,都觉得这些都是标题党文章不予理会的,直到看到 ...

  9. 设计原则&模式:单例模式(创建型)

    定义:某个类只能生成一个实例,该类提供了一个全局访问点供外部获取该实例,其拓展是有限多例模式. 五种实现方式: 饿汉式 懒汉式 双重校验 静态内部类 枚举类 饿汉式 特点:线程安全,调用效率高,但是不 ...

  10. Kafka - 分布式消息队列

    Kafka简介 Kafka原理 Kafka使用 Kafka简介 概念 基于发布/订阅的分布式消息系统 由Linkedin开发,用Scala语言编写 特性 消息持久化:采用时间复杂度O(1)的磁盘存储结 ...