mysql变量赋值要注意的_MySQL
程序员文章站
2022-05-13 19:01:37
...
bitsCN.com
mysql变量赋值要注意的
mysqlsql
今天由于项目需要,需要写个存储过程,这个可是一年才难得写一次。于是没办法,重新捡起来。开始写
写到后来。。
Sql代码 CREATE FUNCTION `getChildLstnotSun`(department_id int) RETURNS varchar(1000) BEGIN DECLARE sTemp VARCHAR(1000); DECLARE sTempChd int; declare fetchSeqOk boolean; declare cur1 CURSOR FOR SELECT departmentId FROM sys_department_info where fatherDepartmentId=department_id; DECLARE CONTINUE HANDLER FOR NOT FOUND SET fetchSeqOk=true; SET fetchSeqOk=false; OPEN cur1; fetchSeqLoop:Loop FETCH cur1 INTO sTempChd; if fetchSeqOk then leave fetchSeqLoop; else SET sTemp := concat(sTemp,',',sTempChd); end if; end loop; CLOSE cur1; RETURN sTemp; END
需要有个类似于for循环字符串拼接的代码
Sql代码 OPEN cur1; fetchSeqLoop:Loop FETCH cur1 INTO sTempChd; if fetchSeqOk then leave fetchSeqLoop; else SET sTemp := concat(sTemp,',',sTempChd); end if; end loop; CLOSE cur1;
结果调试了半天,这个sTemp变量就是不出来.
最后开始奇思妙想。
结果在 SET fetchSeqOk=false;后面加上了 set sTemp='';
这时候才出来了。尼玛,原来这个是需要初始化一下的
顺便记一下,mysql的group_concat函数最好只用在字符串字段上
bitsCN.com
推荐阅读
-
MySQL常见内存不足启动失败的完美解决方法
-
Mysql5.7中使用group concat函数数据被截断的问题完美解决方法
-
Windows 64 位 mysql 5.7以上版本包解压中没有data目录和my-default.ini及服务无法启动的快速解决办法(问题小结)
-
linux下mysql的安装步骤
-
Mysql根据时间查询日期的优化技巧
-
浅谈SQLServer的ISNULL函数与Mysql的IFNULL函数用法详解
-
mysql 终结点映射器中没有更多的终结点可用的解决方法
-
Windows(x86,64bit)升级MySQL 5.7.17免安装版的详细教程
-
mysql 忘记密码的解决方法(linux和windows小结)
-
MySQL 数据库跨操作系统的最快迁移方法