mysql存储过程求大神(拼接字符串) 80

BEGINdeclaretable_nameVARCHAR(100);declarestopFlagint;declaresql1VARCHAR(1000);declar... BEGIN
declare table_name VARCHAR (100);
declare stopFlag int;
declare sql1 VARCHAR (1000);
declare cursor_name cursor
for select TABLE_NAME from information_schema.KEY_COLUMN_USAGE where TABLE_NAME like 'test_2014%';
declare CONTINUE HANDLER FOR NOT FOUND set stopFlag=1;
set @sql1='create or replace view test as select id,name from ';
open cursor_name;
REPEAT
FETCH cursor_name INTO table_name;
begin
set @sql1=CONCAT(@sql1,table_name);
select @sql1;
PREPARE step FROM @sql1;
EXECUTE step;
end;
FETCH cursor_name INTO table_name;
UNTIL stopFlag = 1
END REPEAT;
close cursor_name;
END

如上存储过程,实现的是数据库中有多个表名为test_201409、test_201410....等表格,这些表格结构字段都一样,现在用游标把它们查询出来后,根据这些表创建视图,有一个拼接的过程不会 求大神帮忙看下

拼接后的Sql:
select id,name
from test_201409
union all select id,name from test_201410....

先给80分 好了再给80 求大神
已经解决!
展开
 我来答
0808xyj
2014-11-10 · TA获得超过1891个赞
知道大有可为答主
回答量:1237
采纳率:100%
帮助的人:1077万
展开全部
 DROP PROCEDURE IF EXISTS `p_create_view`

CREATE  PROCEDURE p_create_view()
BEGIN
        DECLARE tableName VARCHAR (100);
        DECLARE stopFlag INT;
        DECLARE sql1 VARCHAR (1000);
        DECLARE cursor_name CURSOR  FOR SELECT TABLE_NAME  FROM information_schema.tables WHERE TABLE_NAME  LIKE 'test_2014%';
        DECLARE CONTINUE HANDLER FOR SQLSTATE '02000'  SET stopFlag=1;
        SET @sql1='create  view test as select id,name from ';
        OPEN cursor_name;
        REPEAT
        FETCH cursor_name INTO tableName;
        SELECT   CONCAT(@sql1,tableName,' UNION ALL SELECT  id,name  FROM ') INTO @sql1 FROM DUAL;  
        UNTIL stopFlag  END REPEAT;
        CLOSE cursor_name;   
        SELECT SUBSTR(@sql1,1,LENGTH(@sql1)-31) INTO @sql1 FROM DUAL;
        PREPARE step FROM @sql1;
        EXECUTE step;
END;
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式