您好,欢迎访问一九零五行业门户网

简简单单储存过程――循环一个select结果集_MySQL

bitscn.com
摘要:本文主要讲解了存储过程的创建、调用、以及游标的使用 ,相信掌握了游标      会对你有不错的帮助,有不足之处还请指教
导航 : 一、存储过程的创建及调用
            二 、游标的使用
            三、  示例
            四、补充
说明:
        1、用到的两个数据表:
from_data
to_data
2、示例需求 : 将表from_data 的select结果集循环插入到表 to_data;
伪代码:   while 循环 select id ,name from_data
insert into to_data(id,name) value(from_data.id,from_data.name)
end
3、环境: mysql
一、存储过程的创建及调用
我们创建一个名叫 add_test的存储过程
1 、检查是否有 add_test
sql代码 
drop procedure if exists add_test;   
       2、创建
sql代码 
create procedure add_test()    
   (    
   #[in|out|inout] 参数 datatype
a int; 
     b int; 
   )    
   begin    
   #sql 语句;
end;
3、调用
sql代码 
call add_test(1,2
);
以上就是基本的创建方法,注意已下几点:
        1 、在建立和调用时,add_test后面的“()”是必须的
        2、mysql 存储过程参数如果不显式指定“in”、“out”、“inout”,则默认为“in”,并且参数不能指定默认值 。
        3、包含多条 sql 语句时,需要 begin end 关键字,在begin end里面的每条语句的末尾,都要加上分号 “;”
        4、在begin end里面声明变量,使用关键字 declare ,如:
sql代码 
begin
#声明一个name变量,类型是varchar(记得分号) 
  name varchar(32);    
end;
二 、游标的使用
1、定义游标
sql代码 
/* 
    定义游标的关键字:cursor。 
    定义游标cursor_name, 
    游标cursor_name当前指针的记录 
    是一个表from_data的多行结果集 
 */ 
  declare cursor_name cursor for select id,name
from from_data;
2、打开游标
sql代码 
#关键字:open 
open cursor_name;
3、 获取游标
sql代码 
#声明两个变量 
  declare a int

  declare b varchar(32)
;
/* 
   fetch 获取游标当前指针的记录,并传给指定变量 a 、b 
*/ 
fetch cursor_name into a,b;
注意:(1、此处很重要,我们在后面的循环例子中会详细讲解如何用,
           (2、注意变量数必须与mysql游标返回的字段数以及类型一致,请看2,3步的标红处,
           a的类型对应 id,b类型对应name
4、关闭游标
sql代码 
close cursor_name ;
以上就是游标的常见使用方法,关键的部分我已在每一步中说明,就不在多说了,现在我们看下例子:
三、示例
sql代码 
drop procedure if exists add_test; 
# 创建存储过程 add_test
create procedure add_test()
begin 
           #定义 变量
declare a int; 
           declare b varchar(30);
#此变可有可无,为了给个该存储函数执行成功后给个提示,运行下便知道
declare str varchar(300); 
           declare x int;
#这个用于处理游标到达最后一行的情况
declare bitscn.com
其它类似信息

推荐信息