在MySQL 存储过程中,查询出来的结果集,不用游标还可以怎么遍历

在MySQL 存储过程中,查询出来的结果集,不用游标还可以怎么遍历,第1张

存储过程返回表类型的值也有二种:

1.存储过程使用浮标参数,即同时指定CURSOR VARYING OUTPUT项.调用者可以使用while及fetch循环遍历该浮标.

2.直接将存储过程返回的结果集插入到表中,即使用insert into 表名 exec 存储过程.此种方式中注意存储过程返回的结果集列与insert的列要完全对应,可以在insert中指定列名来保证对应关系.

------------------------------------------------------------------------------测试:------------------------------------------------------------------------------

----建立测试用的临时表

create table #tmp (colx int,coly int)

insert into #tmp values(1,2)

insert into #tmp values(2,3)

insert into #tmp values(3,4)

select * from #tmpGO----创建返回游标的存储过程

create proc sp_c @cur CURSOR VARYING OUTPUTASbeginset @cur = CURSOR for select colx from #tmp

如果我们有一个包含一亿条数据的表需要取出所以数据,如何通过sql取出。我们能想到有四种方式,但是性能效率会有差别,我们此时进行一下分析,判断该如何选择并实践一下查询分析。

首先我们发现上面type有range和index区分,key都是primary,rows也有分别,那么我们就来直接看下这几种字段的含义。

我们从上面可以看出在大量遍历查询数据的过程中我们应该优先考虑between-and,id>number模式,这样的查询效率会更好一些。

1、新建一个表,比如new-table,包含所要导出的字段的名称,比如a,b,c

2、使用insert into new-table (a,b,c) select a,b,c from old-table

3、剩下的步骤就是导出这个新的表,然后进行文本的处理

方法二、使用MySQL的SELECT INTO OUTFILE 备份语句(推荐)

在下面的例子中,生成一个文件,各值用逗号隔开。这种格式可以被许多程序使用。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6227499.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-18
下一篇 2023-03-18

发表评论

登录后才能评论

评论列表(0条)

保存