CatFood3 2019-03-21 11:35 采纳率: 0%
浏览 3349

关于mysql存储过程递归查询 报错1406 - Data too long for column '' at row

最近要做一个查询 通过递归实现查询到某一个id下面的所有子数据

表结构如下

图片说明图片说明

存储过程代码如下

BEGIN
DECLARE sTemp VARCHAR(4000);
DECLARE sTempChd VARCHAR(4000);

SET sTemp='$';
SET sTempChd = CAST(areaId AS CHAR);

WHILE sTempChd IS NOT NULL DO
SET sTemp= CONCAT(sTemp,',',sTempChd);
SELECT GROUP_CONCAT(CITYID) INTO sTempChd FROM SYSTEM_AREA_CITY WHERE FIND_IN_SET(PARENTID,sTempChd)>0;
END WHILE;
RETURN sTemp;
END

下面是调用存储过程后报错的提示

Procedure execution failed
1406 - Data too long for column 'sTemp' at row 7

  • 写回答

3条回答 默认 最新

  • Keifei 2019-03-22 09:12
    关注

    你这个需要传参,为什么不用函数?

    评论

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?