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] ... 这个语句用指定的打开游标读取下一行(如果有下一行的话),并且前进游标指针。 4. 游标CLOSE语句 CLOSE cursor_name 这个语句关闭先前打开的游标。 四,应用举例 1,测试表和数据 mysql> show create table usersG; //创建一个测试表 *************************** 1. row *************************** Table: users Create Table: CREATE TABLE `users` ( `ID` bigint(20) unsigned NOT NULL AUTO_INCREMENT, `user_name` varchar(60) NOT NULL DEFAULT '', `user_pass` varchar(64) NOT NULL DEFAULT '', PRIMARY KEY (`ID`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 1 row in set (0.00 sec) mysql> select * from users; //测试数据 +----+-----------+-----------+ | ID | user_name | user_pass | +----+-----------+-----------+ | 1 | tank | tank | | 2 | zhang | zhang | | 3 | ying | ying | | 4 | tank | zhang | +----+-----------+-----------+ 4 rows in set (0.00 sec) 2,测试存储过程 mysql> delimiter | mysql> create procedure test_cursor (in param int(10),out result varchar(90)) -> begin -> declare name varchar(20); -> declare pass varchar(20); -> declare done int; -> declare cur_test CURSOR for select user_name,user_pass from test.users; -> declare continue handler FOR SQLSTATE '02000' SET done = 1; -> if param then -> select concat_ws(',',user_name,user_pass) into result from test.users where id=param; -> else -> open cur_test; -> repeat -> fetch cur_test into name, pass; -> select concat_ws(',',result,name,pass) into result; -> until done end repeat; -> close cur_test; -> end if; -> end;| Query OK, 0 rows affected (0.00 sec) 注意,在命令行缩进时,不要用tab,不然会提示, Display all 749 possibilities? (y or n) ? MBRINTERSECTS ABS MBROVERLAPS 。。。 。。。。。。。 1行,创建一个存储过程,注意:如果我把out result varchar(90)改成out result varchar,返回的结果中只有一个字符。 2行,开始 3行,定义一个变量name 4行,定义变量pass 5行,定义一下结束标识 6行,定义一个光标 注意:declare 的内容不要放到if里面,不然会报错误的。 7行,如果sqlstate等于02000时,把done设置成1,也就是找不到数据时 8,10,17行,if判断 9行,根据参数,把数据取出来,放到result中 11行,打开光标 12,15行,repeat循环,根php的do while原理一样 13行,从光标中取出数据。 14行,将数据合并起来 16行,关闭光标 17,18行,标签闭合。 3,测试结果 mysql> call test_cursor(3,@test); Query OK, 0 rows affected (0.00 sec) mysql> select @test; //这里很像php中的,传引用 +-----------+ | @test | +-----------+ | ying,ying | +-----------+ 1 row in set (0.00 sec) mysql> call test_cursor('',@test); Query OK, 0 rows affected, 1 warning (0.00 sec) mysql> select @test; +-------------------------------------------------------+ | @test | +-------------------------------------------------------+ | tank,tank,zhang,zhang,ying,ying,tank,zhang,tank,zhang | +-------------------------------------------------------+ 1 row in set (0.00 sec)