- 浏览: 204362 次
- 性别:
- 来自: 北京
文章分类
最新评论
mysql cursor游标的使用,实例
- 博客分类:
- MySQL&Oracle&MsSql
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)
发表评论
-
Linux下mysql定时备份操作
2012-08-17 16:22 9361.操作系统[root@localhost ~]# ca ... -
mysql 密码修改
2012-08-17 16:24 879>mysql -u root -p Enter pa ... -
CentOS mysqldb 安装
2012-08-13 14:00 1167安装: http://pypi.python.org/pyp ... -
mongodb安装windows服务
2012-07-19 14:46 1087Mongodb的windows服务安装和卸载 ... -
mysql 存储过程中不能使用 return 的解决办法
2012-03-28 15:22 13425大家都知道,mysql 的存储过程是不能使用 ... -
MySQL 存储过程参数用法 in, out, inout
2012-03-28 15:20 854MySQL 存储过程参数有 ... -
mysql 存储过程
2012-03-28 13:51 10371.存储过程只在创造时进行编译,以后每次执行存储过程都不 ... -
在Centos下启用mysql的远程访问账号
2012-02-13 11:32 2206在Centos下启用mysql的远程访问账号 在默 ... -
ubuntu 下安装mysql , mysql允许用户远程连接
2012-02-10 16:35 2863一,安装MySQL sudo apt-get inst ... -
mysql 创建数据库时指定字符
2011-04-08 10:12 1032先mysql进入: GBK: create databa ... -
linux 下导出 mysql 命令
2011-03-28 14:27 1160在linux 下导出 Mysql 数据库的方法 my ... -
mysql 杂谈
2011-03-07 15:06 7881、mysql 连接字符串: select CONCA ... -
mysql 杂谈
2011-03-07 14:57 7361、mysql 连接字符串: select CONCA ... -
centos 下mysql的最常用的操作指令
2010-10-15 15:45 10411、service mysqld status 查看my ... -
在mysql 中导入 .sql 文件
2010-10-15 15:22 936当需要导入到一个mysql 中数据表结构的时候,可以如下操作: ... -
mysql 创建数据库时指定编码
2010-10-15 15:15 1224mysql 创建 数据库时指定编码很重要,很多开发者都使用了默 ...
相关推荐
在MySQL中,创建游标需要使用`DECLARE`语句,语法如下: ``` DECLARE cursor_name CURSOR FOR select_statement; ``` 例如: ``` DECLARE calc_bonus CURSOR FOR SELECT id, salary, commission FROM employees; ```...
在本实例中,我们将探讨如何使用SQL游标来遍历数据并执行相关操作。 首先,让我们理解什么是游标。游标可以视为一个指针,它在查询结果集上移动,允许你逐行访问数据。在大多数关系型数据库管理系统(如MySQL、SQL ...
龙摆尾(坚行).sql.txt和游标实例.sql.txt很可能是包含具体游标使用示例的文件,可能涵盖了诸如迭代处理数据、基于条件更新数据等场景。实际应用中,游标常用于循环执行某个操作,例如批量更新满足特定条件的记录...
以下是对"既简单,又使用的游标实例"的详细解释。 游标,英文名为Cursor,是数据库管理系统(DBMS)提供的一种机制,用于在查询结果集中移动并处理单个记录。它在关系数据库中起着类似指针的作用,可以定位到结果...
本文实例讲述了MySQL游标概念与用法。分享给大家供大家参考,具体如下: 1、游标的概念(Cursor) 一条sql,对应N条资源,取出资源的接口,就是游标,沿着游标,可以一次取出1行。如果开发过安卓的同学应该知道有一...
本文将详细介绍MySQL中的游标概念及其工作原理,并通过实例代码展示如何使用游标。 #### 游标的工作原理 游标可以视为指向数据库查询结果集的指针,使得开发人员能够在应用程序中逐行读取和操作数据。具体流程如下...
在这个示例中,`DECLARE`声明了两个变量`id`和`name`,`DECLARE mc CURSOR FOR`定义了游标`mc`,然后使用`OPEN mc`打开游标,`FETCH`将数据存入变量,`INSERT`将数据插入新表,最后`CLOSE mc`关闭游标。 ### 游标...
这个实例展示了如何在MySQL存储过程中使用游标处理数据,通过逐行读取和更新记录,实现了特定业务逻辑的需求。在实际应用中,这样的存储过程可以提高代码的复用性和效率,同时简化复杂操作的管理。
在本文中,我们将深入探讨如何连接到MySQL数据库,提供实例教程,以便更好地理解和实践。 首先,了解MySQL连接的基础知识至关重要。连接到MySQL数据库通常涉及以下四个核心元素: 1. **服务器地址(Host)**:这是...
MYSQL 数据库高级应用宝典含实例(索引、视图、触发器、游标和存储过程) MYSQL 数据库高级应用宝典含实例中,涵盖了索引、视图、触发器、游标和存储过程等高级应用领域。下面我们将逐一介绍这些高级应用领域的知识点...
BEGIN -- 声明变量 ... /** 声明游标,并将查询结果存到游标中 **/ DECLARE c_borrow CURSOR FOR SELECT ID from rocky_borrow WHERE BORROWTYPE = 2 AND PUBLISH_TIME >= UNIX_TIMESTAMP('2014-
在SQL Server或MySQL中,我们可以使用DECLARE、OPEN、FETCH和CLOSE语句来管理游标。以下是一个SQL Server的例子: ```sql DECLARE @var1 datatype1, @var2 datatype2; DECLARE cursor_name CURSOR FOR SELECT column...
MySQL则是一种广泛使用的开源关系型数据库管理系统,因其高效、稳定和易于扩展而受到青睐。将Python与MySQL结合使用,可以实现强大的数据管理和分析功能。这篇“Python操作MySQL实例教程手册”将深入探讨如何通过...
MySQL中的游标使用`DECLARE CURSOR`定义,`FETCH`语句用于获取当前行,`CLOSE`关闭游标。在示例中,有两个游标:`cur`用于获取临时表的任务数据,`cur2`用于检查正式表中是否存在相同的记录。 **事务(Transaction...
在本实例中,游标被用来处理商户关联数据的插入和更新。 首先,我们来看批量插入商户路由关联数据的过程。在这个例子中,声明了多个变量,如`v_partner_no`、`v_partner_id`、`v_sc_pid`等,用于存储从`anl_partner...
例1、一个简单存储过程游标实例 代码如下: DELIMITER $$ DROP PROCEDURE IF EXISTS getUserInfo $$CREATE PROCEDURE getUserInfo(in date_day datetime)— — 实例— 存储过程名为:getUserInfo— 参数为:date_day...
3. 执行SQL语句:通过连接对象的cursor()方法获取一个游标对象,之后使用该游标对象的execute()方法执行SQL命令。游标对象对于处理查询结果集尤为重要。 4. 获取结果集:通过fetchone()方法获取单行结果,或者使用...
使用for循环和游标对象的`execute()`方法,将DataFrame的每一行数据插入到MySQL中。 ```python for index, row in data.iterrows(): cursor.execute(sql_insert, row.values) # 提交事务 conn.commit() # 关闭...