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)

mysql cursor使用变量_mysql cursor游标的使用,实例相关推荐

  1. mysql查询语句 变量_mysql查询语句中用户变量的使用

    先上代码吧 SELECT `notice`.`id` , `notice`.`fid` , `notice`.`has_read` , `notice`.`notice_time` , `notice ...

  2. mysql 查询绑定变量_MySQL高级特性——绑定变量

    从MySQL 4.1 版本开始,就支持服务器端的绑定变量,这大大提高了客户端和服务器端数据传输的效率 介绍 当创建一个绑定变量 SQL 时,客户端会向服务器发送一个SQL语句的原型.服务器端收到这个S ...

  3. mysql 设置查询变量_MySQL查询优化--调整内部变量的详解

    MySQL是如此的开放,所以可轻松地进一步调整其缺省设置以获得更优的性能及稳定性.需要优化的一些关键变量如下: 改变索引缓冲区长度(key_buffer) 一般,该变量控制缓冲区的长度在处理索引表(读 ...

  4. mysql 生明变量_MySql中的变量定义

    根据mysql手册,mysql的变量分为两种:系统变量和用户变量.但是在实际使用中,还会遇到诸如局部变量.会话变量等概念.根据个人感觉,mysql变量大体可以分为四种类型: 一.局部变量. 局部变量一 ...

  5. mysql内置变量_MySQL常用内置变量

    MySQL用很多常用的内置变量,掌握这些内置变量后对于我们快速获取当前MySQL的配置有很大帮助,下面就来列举几个常用的变量. 查看当前MySQL版本号信息.show variables like ' ...

  6. mysql 声明时间变量_MySQL如何声明一个datetime变量?

    要声明日期时间变量,您需要使用SET命令使用用户定义的变量.语法如下-SET @anyVariableName='yourdatetimeValue'; 为了理解上述语法,让我们创建一个表.创建表的查 ...

  7. mysql创建用户变量_MySQL创建一个变量的用户?

    您可以为此使用动态查询.首先为用户名设置变量名,为密码设置变量名.语法如下-SET @anyVariableName='yourUserName'; SET @anyVariableName1='yo ...

  8. mysql 删除用户变量_MySql安装与MySQL添加用户、删除用户与授权

    MySql中添加用户,新建数据库,用户授权,删除用户,修改密码(注意每行后边都跟个;表示一个命令语句结束): 1.新建用户 1.1 登录MYSQL: @>mysql -u root -p @&g ...

  9. mysql 触发器定义变量_MySQL 函数存储过程触发器定义简单示例

    1.变量提示 NEW 是新值-- OLD 是旧值 INSERT 只有NEW ----UPDATE有NEW和OLD ---DELETE只有OLD 2.准备测试表(userinfo.userinfolog ...

最新文章

  1. R语言使用lm函数拟合多元线性回归模型、假定预测变量没有交互作用(Multiple linear regression)
  2. MyBatis 批量更新,批量更新
  3. 美国伊利诺伊大学香槟分校计算机专业,伊利诺伊大学香槟分校计算机科学排名第7(2020年TFE美国排名)...
  4. angularjs全栈开发知乎_1-4【微信小程序全栈开发课程】原生小程序框架介绍
  5. Win10如何屏蔽删除电脑右下角的广告
  6. Python数据结构与算法(五)--链表
  7. 如何配置x225/x235/x335/x345的LSI SCSI卡实现RAID-1功能
  8. 国盾量子等参与中国量子通信行业首批标准编制 量子通信商用再加速
  9. Linux Crontab内环境变量与Shell环境变量的关系及解决问题的办法
  10. Web前端前景、最新技术、学习路线?
  11. 论文|SDNE的算法原理、代码实现和在阿里凑单场景中的应用说明(附代码)
  12. NumPy中如何确定两个ndarray数组完全相同
  13. pandas读取csv文件数据并对数据分类使用matplotlib画出折线图
  14. 解决办法:undefined reference to symbol 'shm_open@@GLIBC_2.2.5'
  15. java cron定时器在线生成规则
  16. 熵、互信息与相对熵的关系
  17. tekla钢结构算量_钢结构、Tekla及建筑工业化厂商对Tekla软件的开发和应用
  18. 通过51单片机开发板USB转TTL模块烧录ESP8266-01固件
  19. 第三届同花顺算法大赛 | 2022 | AI算法
  20. k8s多节点仪表盘(web界面 ) dashboard 部署 与 谷歌浏览器访问仪表盘问题

热门文章

  1. 电脑文件里哪里能用计算机,如何搜索电脑文件和文件夹
  2. 【软件测试学习笔记】接口自动化测试基础-Day1 网络协议 2020-09-21
  3. 网页版 连连看 html5实现
  4. 最常用计算机文件后缀名,文件扩展名/后缀名是什么 常用的文件扩展名大全
  5. 编译Python时报错:configure: error: no acceptable C compiler found in $PATH
  6. C/C++程序员必看——豆瓣评分9.0+的经典
  7. 小白的测试人生(三)小白如何进入IT行业及如何选择培训机构
  8. VS 2019 命令提示符 相关命令
  9. 有一个类似”abbc,d d.eeffgg,59.30ABDFR ”这样的包含大小写字母,数字,空格,逗号和句号的字符串,求各字符的数量。(设计一个一个函数,传入字符串,返回各字符数量的数据)
  10. CentOS7 安装cellranger-4.0.0