mysql cursor游标的使用,实例
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游标的使用,实例的更多相关文章
- cursor游标(mysql)
/* 游标 cursor 什么是游标?为什么需要游标 使用存储过程对sql进行编程的时候,我们查询的语句可能是数据是多个,它总是一口气全部执行,我们无法针对每一条进行判断.也就是说,我们无法控制程序的 ...
- 利用navicat创建存储过程、触发器和使用游标的简单实例
利用navicat创建存储过程.触发器和使用游标的简单实例 标签: navicat存储过程触发器mysql游标 2013-08-03 21:34 15516人阅读 评论(1) 收藏 举报 分类: 数 ...
- python操作mysql数据库的相关操作实例
python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...
- MySQL中游标使用以及读取文本数据
原文:MySQL中游标使用以及读取文本数据 前言 之前一直没有接触数据库的学习,只是本科时候修了一本数据库基本知识的课.当时只对C++感兴趣,天真的认为其它的课都没有用,数据库也是半懂不懂,胡乱就考试 ...
- MySQL存储过程 游标
MySQL存储过程 游标 如何在存储过程中使用MySQL游标来遍历SELECT语句返回的结果集 MySQL游标简介 要处理存储过程中的结果集,请使用游标.游标允许您迭代查询返回的一组行,并相应地处理 ...
- 转 oracle cursor 游标
转自:http://blog.csdn.net/liyong199012/article/details/8948952 游标的概念: 游标是SQL的一个内存工作区,由系统或用户以变量的形式定 ...
- MySQL Cursor
MySQL Cursor Summary: in this tutorial, you will learn how to use MySQL cursor in stored procedures ...
- 【PLSQL】变量声明,结构语句,cursor游标
************************************************************************ ****原文:blog.csdn.net/clar ...
- Spring 4 MVC+Hibernate 4+MySQL+Maven使用注解集成实例
Spring 4 MVC+Hibernate 4+MySQL+Maven使用注解集成实例 转自:通过注解的方式集成Spring 4 MVC+Hibernate 4+MySQL+Maven,开发项目样例 ...
随机推荐
- C++11线程使用总结
std::thread 在 <thread> 头文件中声明,因此使用 std::thread 需包含 <thread> 头文件. <thread> 头文件摘要 &l ...
- RHEL 7中有关终端的快捷方式
快速启动终端 网上有不错的教程,只是有时候和版本有一定的出入,这里涉及小白博主自行摸索的过程(RHEL 7.4). 1.点击桌面右上角,选择设置(小扳手) 2.选择键盘(Keyboard) 3.将进度 ...
- 导入(移动)数据到hive1.1.0表的方法
hive数据导入代码格式(会移动源文件位置): LOAD DATA [LOCAL] INPATH 'filepath' [OVERWRITE] INTO TABLE tablename [partit ...
- Linux应用编程之串口操作20170901
主要介绍在Linux应用程序下对串口的操作: 1.串口初始化 int InitCom() { int Ret; Ret = SerailComm.OpenCom( ComPortDevPath, 0 ...
- navicat for mysql 导出数据的坑
navicat 选择转储结构和数据的时候,生成的 sql 文件会比较大,因为每一条数据都会生成一条 sql 语句,所以会导致 使用 source 还原的时候会很慢很慢很慢, 而使用 mysqldump ...
- linux内核支持nfs挂载配置
1.配置网络部分,主要是使能CONFIG_IP_PNP以在2中能够看到Root file system on NFS选项Networking support Networking options TC ...
- 第4章-Vue.js 交互及实例的生命周期
一.学习目标 了解实例生命周期的过程 理解钩子函数的作用 掌握Vue.js过滤器的使用方法 (重点) 能够使用网络请求进行前后端交互 (重点.难点) 二.交互的基本概念 2.1.前端和后端的概念 说明 ...
- 让块元素在同一行显示的方法: float 和inline-block
float: 定义:按照一个指定的方向移动,遇到父级的边界或者相邻的浮动元素就会停下来(不完全脱离文档流) 值: left.right.none 特点: 1.浮动的块元素可以在一行显示,宽度是被内容撑 ...
- 前端PHP入门-011-可变函数
可变函数,我们也会称呼为变量函数.简单回顾一下之前的知识点: <?php $hello = 'world'; $world = '你好'; //输出的结果为:你好 echo $$hello; ? ...
- click和mousedown的区别
$("button").mousedown(function(){ $("p").slideToggle(); }); 当鼠标指针移动到元素上方,并按下鼠标按键 ...