返回顶部
首页 > 资讯 > 数据库 >MySQL函数与存储过程字符串长度限制的解决
  • 849
分享到

MySQL函数与存储过程字符串长度限制的解决

MySQL存储过程字符串长度限制MySQL字符串长度限制 2022-08-15 10:08:11 849人浏览 独家记忆
摘要

目录问题描述原因分析:解决方案:问题描述 Mysql函数或者存储过程中使用group_concat()函数导致数据字符过长而报错 CREATE DEFINER=`root`@`%` PROCEDURE `get

问题描述

Mysql函数或者存储过程中使用group_concat()函数导致数据字符过长而报错

CREATE DEFINER=`root`@`%` PROCEDURE `get_pipe_child`(IN `in_pipe2Num` varchar(25),IN `in_sectionNum` varchar(5))
BEGIN

declare ids varchar(1000) default '';
declare tempids varchar(1000);

-- 先根据标段号查询出数据组成临时表
DROP TEMPORARY TABLE IF EXISTS temp_weld_position;
CREATE TEMPORARY TABLE temp_weld_position AS
select t1.id,t1.section_num,t1.weld_code,t1.lon,t1.lat,t2.pipe1_num,t2.pipe2_num from
 (select id,section_num,weld_code,lon,lat from weld_position where section_num = in_sectionNum and LENGTH(lon)>=7 and LENGTH(lat)>=6 and is_deleted=0) t1
 join (select id,weld_code,pipe1_num,pipe2_num from weld_manage where section_num = in_sectionNum) t2 on t1.weld_code=t2.weld_code;

-- 在根据传入的pipe2_num 递归查询出所有的数据,将pipe2_num当做id,pipe1_num当pid
set tempids = in_pipe2Num;
while tempids is not null do
 set ids = CONCAT_WS(',',ids,tempids);
 select GROUP_CONCAT(pipe2_num) into tempids from temp_weld_position where FIND_IN_SET(pipe1_num,tempids)>0; 
end while;

 select t1.id,t1.section_num,t1.weld_code,t1.lon,t1.lat,t2.pipe1_num,t2.pipe2_num from
 (select id,section_num,weld_code,lon,lat from weld_position where section_num = in_sectionNum and LENGTH(lon)>7 and LENGTH(lat)>6 and is_deleted=0) t1
 join (select id,weld_code,pipe1_num,pipe2_num from weld_manage where section_num = in_sectionNum) t2 on t1.weld_code=t2.weld_code
 where FIND_IN_SET(t2.pipe2_num,ids)
 order by FIND_IN_SET(t2.pipe2_num,ids);    
END

原因分析:

两个参数ids、tempids定义的varchar(1000),后续执行多次循环,GROUP_CONCAT拼接字符放入这两个参数时就会报字符串长度超限错误,因函数、存储过程中varchar类型最大长度为16383

解决方案:

将varchar(1000)类型变成text或者是BLOB类型解决此问题

到此这篇关于mysql函数与存储过程字符串长度限制的解决的文章就介绍到这了,更多相关Mysql函数与存储过程字符串长度限制内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL函数与存储过程字符串长度限制的解决

本文链接: https://lsjlt.com/news/33693.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作