免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2676 | 回复: 2
打印 上一主题 下一主题

存储函数运行起来终端就不响应了 [复制链接]

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2015-10-29 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-10-26 14:53 |只看该作者 |倒序浏览
下面是我写的一个函数,功能是把公式中的每个变量替换为对应的值
delimiter //

create function func_test01(formula varchar(800),in_ind_id_str varchar(800),in_ind_val_str varchar(800)) returns text(800) DETERMINISTIC
begin
  declare l_formula varchar(800);
  declare ind_id varchar(20);
  declare ind_val varchar(20);
  declare id1 int(4) default 0;
  declare len int(4) default 0;
  declare tmp_str varchar(800);
  declare ind_id_str varchar(800);
  declare ind_val_str varchar(800);
  
  set l_formula = formula;
  set ind_id_str = in_ind_id_str;
  set ind_val_str = in_ind_val_str;
  
while instr(ind_id_str,',')>0 do

  set len = length(ind_id_str);
  set id1 = instr(ind_id_str,',');
  set ind_id = left(ind_id_str,id1-1);
  set tmp_str = right(ind_id_str,len+1-id1);
  set ind_id_str = tmp_str;

  set len = length(ind_val_str);
  set id1 = instr(ind_val_str,',');
  set ind_val = left(ind_val_str,id1-1);
  set tmp_str = right(ind_val_str,len+1-id1);
  set ind_val_str = tmp_str;

  set l_formula = replace(l_formula,ind_id,ind_val);

end while;

  set l_formula = replace(l_formula,ind_id_str,ind_val_str);
  return l_formula;
  
end;

当我运行时,mysql终端就没有反应了,例如:select('L1+L2','L1,L2','1,2');

貌似没有死循环啊

提前谢谢各位大侠帮俺看看

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2015-10-29 06:20:00
2 [报告]
发表于 2015-10-26 14:57 |只看该作者
这时候连drop这个函数也都没有反应

操作其他表格,过程都是正常的

论坛徽章:
154
2022北京冬奥会纪念版徽章
日期:2015-08-07 17:10:5720周年集字徽章-年
日期:2022-10-26 16:44:2015-16赛季CBA联赛之深圳
日期:2022-11-02 14:02:4515-16赛季CBA联赛之八一
日期:2022-11-28 12:07:4820周年集字徽章-20	
日期:2023-07-19 08:49:4515-16赛季CBA联赛之八一
日期:2023-11-04 19:23:5115-16赛季CBA联赛之广夏
日期:2023-12-13 18:09:34
3 [报告]
发表于 2015-10-27 23:19 来自手机 |只看该作者
是不是死循环了,还是表本身就很大
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP