• 云途科技成立于2010年 - 专注全球跨境电商服务器租赁托管!
  • 帮助中心

    您可以通过下方搜索框快速查找您想知道的问题

    mysql cursor游标的使用,实例

      in  数据库      Tags: 

    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)


    • 外贸虚拟主机

      1GB硬盘

      2个独立站点

      1000M带宽

      不限制流量

      美国外贸专用虚拟主机,cPanel面板,每天远程备份.
      服务器配置:2*E5 32核,96GB 内存,4*2TB 硬盘 RAID10 阵列.

      ¥180/年

    • 美国/荷兰外贸VPS

      2核CPU

      1G内存

      30硬盘

      10M带宽

      美国/荷兰外贸云服务器,专注外贸服务器行业12年.
      服务器配置:2*E5 32核,96GB 内存,4*2TB 硬盘 RAID10 阵列.

      ¥99/月

    • 全球外贸服务器

      8核CPU

      32G内存

      1TB硬盘

      1000M带宽

      已部署数据中心:美国洛杉矶/亚特兰大、荷兰、加拿大、英国伦敦、德国、拉脱维亚、瑞典、爱沙尼亚
      自有机柜(全球九大数据中心),稳定在线率:99.9%

      ¥999/月 原价1380

    7*24小时 在线提交工单

    如果您的问题没有得到解决,推荐您在线提交工单,我们的客服人员会第一时间为您解决问题

    展开