Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2856460
  • 博文数量: 471
  • 博客积分: 7081
  • 博客等级: 少将
  • 技术积分: 5369
  • 用 户 组: 普通用户
  • 注册时间: 2012-01-04 21:55
文章分类

全部博文(471)

文章存档

2014年(90)

2013年(69)

2012年(312)

分类: Mysql/postgreSQL

2012-03-22 15:46:17

mysql被oracle收购后,从mysql-5.5开始,将InnoDB作为默认存储引擎,是一次比较重大的突破。InnoDB作为支持事务的存储引擎,拥有相关的
RDBMS特性:包括ACID事务支持,数据完整性(外健),灾难恢复能力等特性。
使用mysql做为数据库的话,将来程序员肯定要写很多,存储过程,function等。在写些东东的时候,游标肯定是少不了的。下面简单简介一下。
一,什么是游标(cursor)
个人觉得就是一个cursor,就是一个标识,用来标识数据取到什么地方了。你也可以把它理解成数组中的下标。
二,游标(cursor)的特性
1,只读的,不能更新的。
2,不滚动的
3,不敏感的,不敏感意为服务器可以活不可以复制它的结果表
游标(cursor)必须在声明处理程序之前被声明,并且变量和条件必须在声明游标或处理程序之前被声明。
三,使用游标(cursor)
1.声明游标
DECLARE cursor_name CURSOR FOR select_statement
这个语句声明一个游标。也可以在子程序中定义多个游标,但是一个块中的每一个游标必须有唯一的名字。声明游标后也是单条操作的,但是不
能用SELECT语句不能有INTO子句。
2. 游标OPEN语句
OPEN cursor_name
这个语句打开先前声明的游标。

3. 游标FETCH语句
FETCH cursor_name INTO var_name [, var_name] ...
这个语句用指定的打开游标读取下一行(如果有下一行的话),并且前进游标指针。
     Mysql是通过一个Error handler的声明来进行判断的指针是否到尾,
     declare continue handler for Not found (do some action);
 在Mysql里当游标遍历溢出时,会出现一个预定义的NOT FOUND的Error,我们处理这个Error并定义一个continue的handler就可以了。
定义一个flag,在NOT FOUND,标示Flag,在Loop里以这个flag为结束循环的判断就可以了。

  4. 游标CLOSE语句
CLOSE cursor_name
这个语句关闭先前打开的游标。
 
注意:MySQL的游标是向前只读的,也就是说,你只能顺序地从开始往后读取结果集,不能从后往前,也不能直接跳到中间的记录.

1、 无返回结果语句,如:INSERT,UPDATE,DROP, DELETE等

2、 select语句返回单行变量并可传给本地变量(select ..into)

3、 返回多行结果集的select语句,并可使用MySQL游标循环处理


 
  1. CREATE TABLE `users`
  2.  (
  3.  `ID` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
  4.  `user_name` varchar(60),
  5.  `user_pass` varchar(64),
  6.  PRIMARY KEY (`ID`)
  7. ) ENGINE=InnoDB AUTO_INCREME


  8. insert into users values(null,'tank','tank'),
  9. (null,'zhang','zhang'),
  10. (null,'ying','ying');

  11. create procedure test_cursor (in param int(10),out result varchar(90))
  12. begin
  13.      declare name varchar(20);
  14.      declare pass varchar(20);
  15.      declare done int;
  16.      declare cur_test CURSOR for select user_name,user_pass from users;
  17.      declare continue handler FOR SQLSTATE '02000' SET done = 1;
  18.      if param then
  19.         select concat_ws(',',user_name,user_pass) into result from users where id=param;
  20.      else
  21.          open cur_test;
  22.             repeat
  23.                  fetch cur_test into name, pass;
  24.                  select concat_ws(',',result,name,pass) into result;#返回给本地变量输出
  25.               until done
  26.             end repeat;
  27.         close cur_test;
  28.      end if;
  29.  end;

  30. call test_cursor(3,@test);
  31. select @test
将上面表users的名字全部变为king

点击(此处)折叠或打开

  1. create PROCEDURE pro_users()
  2. begin
  3.      DECLARE result varchar(128);
  4.      DECLARE no int;
  5.      DECLARE cur_1 CURSOR FOR SELECT user_name FROM users; #把select出来的数据全部保存到游标cur_1中
  6.      DECLARE CONTINUE HANDLER FOR NOT FOUND SET no=1; #当读到数据的最后一条时,设置no变量为1
  7.      SET no=0; #初始化变量no为0
  8.      OPEN cur_1; #打开游标
  9.            while no=0 do #判断是不是到了最后一条数据
  10.                  fetch cur_1 into result; #读取游标中的数据一一复给变量result。
  11.                   update users set user_name='king' where user_name=result;#这个不用解释了吧
  12.            end while;
  13.      close cur_1;#最后关闭游标.游标里面存放了那么多数据总是要清理掉的吧。
  14. end

  15. call pro_users()


 
阅读(10198) | 评论(1) | 转发(0) |
0

上一篇:mysql游标实例3

下一篇:深度优先搜索

给主人留下些什么吧!~~

nba76ers2014-01-21 09:20:46

游标必须定义在变量/条件后,handler前;否则会报错。
   ERROR 1337 (42000): Variable or condition declaration after cursor or handler declaration