> 데이터 베이스 > MySQL 튜토리얼 > mysql变量赋值要注意的_MySQL

mysql变量赋值要注意的_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-01 13:30:50
원래의
1083명이 탐색했습니다.

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
관련 라벨:
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿