php mysql 数据游标_<转>mysql cursor游标的使用,实例

本文介绍了MySQL中的游标概念及其特性,包括只读性、不滚动和不敏感等特点。通过示例详细讲解了如何声明、打开、读取和关闭游标,并提供了一个存储过程的应用实例,展示了在不同条件下如何使用游标处理数据。
摘要由CSDN通过智能技术生成

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 users\G;      //创建一个测试表

*************************** 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)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
游标是一种在 MySQL 中用于遍历结果集的机制,它允许程序员逐行访问查询结果,并对每一行进行操作。下面是一个 MySQL 游标的简单实例: 假设有一个名为 `employees` 的表,其中包含员工的信息,如下所示: | id | name | age | salary | | --- | -------- | --- | ------ | | 1 | John Doe | 35 | 50000 | | 2 | Jane Doe | 28 | 40000 | | 3 | Bob Smith | 42 | 60000 | | 4 | Mary Johnson | 25 | 35000 | 现在,假设我们想要遍历这个表,并计算所有员工的平均薪资。我们可以使用以下游标实现: ``` DECLARE total_salary INT DEFAULT 0; DECLARE num_employees INT DEFAULT 0; DECLARE avg_salary FLOAT DEFAULT 0; DECLARE cur CURSOR FOR SELECT salary FROM employees; DECLARE CONTINUE HANDLER FOR NOT FOUND SET @finished = TRUE; OPEN cur; read_loop: LOOP FETCH cur INTO salary; IF @finished THEN LEAVE read_loop; END IF; SET total_salary = total_salary + salary; SET num_employees = num_employees + 1; END LOOP; CLOSE cur; SET avg_salary = total_salary / num_employees; SELECT avg_salary; ``` 这个游标实例中,我们首先声明了一些变量,包括总薪资、员工总数和平均薪资。然后,我们声明了一个名为 `cur` 的游标,用于遍历 `employees` 表中的 `salary` 列。我们使用 `OPEN` 命令打开游标,并使用 `FETCH` 命令从游标中获取每一行的 `salary` 值。我们使用一个 `LOOP` 块来遍历所有行,直到遇到 `NOT FOUND` 错误,表示已经遍历完所有行。在循环中,我们将每一行的 `salary` 值加到总薪资中,并增加员工总数。最后,我们使用 `CLOSE` 命令关闭游标,计算平均薪资,并输出结果。 注意,在使用游标时,需要小心性能问题。游标会在内存中缓存查询结果,并且会占用大量内存,特别是当查询结果集非常大时。因此,如果可能的话,应该尽量避免使用游标,而尝试使用更有效的查询和操作方式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值