mysql procedure

drop PROCEDURE if EXISTS GetTotal;
#str_num,numbers of string array
#str_arr,array of strings
CREATE PROCEDURE GetTotal(IN str_num int,IN str_arr VARCHAR(10000))
BEGIN
declare idx int default 1;
declare total int default 0;
declare c int default 0;
#declare tablename varchar(50);
	LOOP_LABLE:loop
		select count(*) into c from (select SUBSTRING_INDEX(SUBSTRING_INDEX(str_arr, ' ', idx), ' ', -1)) as tablename;# where isNew=1;
		#set tablename=SUBSTRING_INDEX(SUBSTRING_INDEX(str_arr, ' ', idx), ' ', -1);select tablename;
		set total=total+c;
		set idx=idx+1;
		if idx>str_num THEN
			leave LOOP_LABLE;
		end if;
	end loop;
select total;
END

call GetTotal(2,'Auto Ent');


本来是要折腾一个通过参数将多个表名传到存储过程去批量统计记录总数的,到了将参数转换成表名那一步就实现不了了,然后突然间又用不了这么做了,先mark it down吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值