MySQL 存储过程 SELECT ... 查询为空 INTO ... 变量不做修改

这几天写了一个存储过程通过父级id循环来处理机构区划字段

 

在这里插入图片描述
在这里插入图片描述

在执行存储过程中,我发现只有几百条数据却执行几十秒都没结束,最后逐步排查发现。

有一个机构有父级id但是父级id查询数据为空,然后WHILE就陷入死循环无法退出

加上日志排查为啥会这样,发现:

MySQL在SELECT没有查找到记录,影响行数为0,不会执行INTO的操作,导致变量里面保存的是前一次会话中的结果,导致 IF parentOrgId IS NULL 判断失效 导致陷入死循环

后续在SELECT … INTO … 语句前赋值变量为空,测试后解决该问题
在这里插入图片描述

搜索文章后有人说SQL Service则不会有这种问题,以前公司用的Oracle换成MySQL,数据之间的差异还是造成了挺多的问题

非常感谢您的提问!以下是关于MySQL存储过程和函数的实验报告: MySQL实验报告5(存储过程与函数) 一、实验目的 了解MySQL存储过程和函数的基本概念和使用方法,掌握存储过程和函数的创建、调用、修改和删除。 二、实验环境 - 操作系统:Windows 10 - 数据库管理系统:MySQL 5.7.26 - 开发工具:Navicat Premium 12 三、实验步骤 3.1 存储过程的创建和调用 存储过程是一段可重复使用的SQL代码块,可以通过一个名称和参数列表来调用。下面是一个简单的存储过程示例: ```sql DELIMITER // CREATE PROCEDURE `get_user`(IN id INT, OUT name VARCHAR(20), OUT age INT) BEGIN SELECT user_name, user_age INTO name, age FROM user WHERE user_id = id; END // DELIMITER ; ``` 该存储过程的功能是根据用户ID获取用户的姓名和年龄。在创建存储过程时,需要使用DELIMITER命令指定分隔符为//,以便于在存储过程中使用多个分号。CREATE PROCEDURE语句定义了存储过程的名称和参数列表。IN表示输入参数,OUT表示输出参数。在存储过程的BEGIN和END之间编写SQL语句,完成存储过程的功能。最后使用DELIMITER命令将分隔符还原为;。 调用存储过程可以使用CALL语句,例如: ```sql CALL get_user(1, @name, @age); SELECT @name, @age; ``` 该语句将会获取用户ID为1的用户姓名和年龄,并将结果分别存储到变量@name和@age中。最后通过SELECT语句将变量的值输出。 3.2 存储函数的创建和调用 存储函数是一段可重复使用的SQL代码块,可以通过一个名称和参数列表来调用。与存储过程不同的是,存储函数必须有一个返回值。下面是一个简单的存储函数示例: ```sql DELIMITER // CREATE FUNCTION `get_user_age`(IN id INT) RETURNS INT BEGIN DECLARE age INT; SELECT user_age INTO age FROM user WHERE user_id = id; RETURN age; END // DELIMITER ; ``` 该存储函数的功能是根据用户ID获取用户的年龄。在创建存储函数时,需要使用DELIMITER命令指定分隔符为//,以便于在存储函数中使用多个分号。CREATE FUNCTION语句定义了存储函数的名称和参数列表,并使用RETURNS关键字指定返回值的类型。在存储函数的BEGIN和END之间编写SQL语句,完成存储函数的功能。最后使用RETURN命令返回函数的结果。在存储函数中可以使用DECLARE命令定义局部变量。 调用存储函数可以使用SELECT语句,例如: ```sql SELECT get_user_age(1); ``` 该语句将会获取用户ID为1的用户年龄,并将结果输出。 3.3 存储过程和函数的修改和删除 存储过程和函数可以使用ALTER语句进行修改,例如: ```sql ALTER PROCEDURE `get_user`(IN id INT, OUT name VARCHAR(20), OUT age INT) BEGIN SELECT user_name, user_age INTO name, age FROM user WHERE user_id = id; UPDATE user SET user_name = 'Tom' WHERE user_id = id; END ``` 该语句将会修改get_user存储过程的功能,在返回用户姓名和年龄的同时,将用户的姓名修改为Tom。 存储过程和函数可以使用DROP语句进行删除,例如: ```sql DROP PROCEDURE IF EXISTS `get_user`; DROP FUNCTION IF EXISTS `get_user_age`; ``` 该语句将会删除get_user存储过程和get_user_age存储函数。 四、实验总结 本次实验学习了MySQL存储过程和函数的基本概念和使用方法,掌握了存储过程和函数的创建、调用、修改和删除。在实际开发中,存储过程和函数可以提高SQL代码的重用性和可维护性,提高数据库的性能和安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值