首页 > 编程知识 正文

mysql游标多个字段,在mysql中,存储过程可以声明和使用游标吗

时间:2023-05-04 23:21:49 阅读:238428 作者:4992

从mysql V5.5开始,进行了一次大的改变,就是将InnoDB作为默认的存储引擎。InnoDB支持事务,而且拥有相关的RDBMS特性:ACID事务支持,数据完整性(支持外键),灾难恢复能力等等。

现在简单总结一下游标的知识。

(一),认识游标(cursor)

就是一个可读的标识,用来标识数据取到什么地方了。

(二),游标特性

1,只读

2,不滚动

3,不敏感的

(三),使用游标

需要强调的是,游标必须在定义处理程序之前被定义,但变量必须在定义游标之前被定义,顺序就是变量定义-游标定义-处理程序。

1.定义游标

DECLARE cursor_name CURSOR FOR select_statement

这个语句声明一个游标。也可以在子程序中定义多个游标,一个块中的每一个游标必须命名唯一。声明游标后也是单条操作的。

2. 游标OPEN

OPEN cursor_name--这个语句打开先前声明的游标。

3. 游标FETCH

FETCH cursor_name INTO var_name [, var_name] ...

这个语句用指定的打开游标读取下一行(如果有下一行的话),并且前进游标指针至该行。

4. 游标CLOSE

CLOSE cursor_name

5.清除游标

declear cursor_name

这个语句关闭先前打开的游标,注意,用完后必须关闭。

(四)示例,下面是一个存储过程,里面用到游标,逐条更新数据(批量更新数据)

BEGIN

DECLARE no_more_record INT DEFAULT 0;DECLARE pID BIGINT(20);DECLARE pValue DECIMAL(15,5);DECLARE cur_record CURSOR FOR SELECT colA, colB from tableABC; /*首先这里对游标进行定义*/

DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_more_record = 1; /*这个是个条件处理,针对NOT FOUND的条件,当没有记录时赋值为1*/

OPEN cur_record; /*接着使用OPEN打开游标*/

FETCH cur_record INTO pID, pValue; /*把第一行数据写入变量中,游标也随之指向了记录的第一行*/

WHILE no_more_record != 1DOINSERT INTOtestTable(ID, Value)VALUES(pID, pValue);FETCH cur_record INTOpID, pValue;END WHILE;CLOSE cur_record; /*用完后记得用CLOSE把资源释放掉*/

END

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。