- 浏览: 2510024 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (676)
- linux运维 (157)
- php (65)
- mysql (78)
- nginx (27)
- apche (18)
- framework (6)
- windows (9)
- IDE工具 (23)
- struts2 (7)
- java (13)
- 移动互联网 (14)
- memcache redis (23)
- shell基础/命令/语法 (37)
- shell (50)
- puppet (4)
- C (11)
- python (9)
- 产品经理 (27)
- Sphinx (4)
- svn (12)
- 设计构建 (12)
- 项目管理 (44)
- SEO (1)
- 网站架构 (26)
- 审时度势 (42)
- 网络 (14)
- 激发事业[书&视频] (81)
- 其它 (12)
- 摄影 (8)
- android (21)
最新评论
-
zhongmin2012:
原文的书在哪里
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
renzhengzhi:
你好,请问个问题,从master同步数据到slave的时候,s ...
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
ibc789:
你好,看了你的文章,我想请教个问题, 我在用 redis的时候 ...
redis 的两种持久化方式及原理 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器
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表修复
2015-04-07 10:16 102311.1命令myisamchk(必须停掉mysql服务,或者所操 ... -
Table_locks_immediate
2014-08-25 15:46 2959Table_locks_immediate表示立即释放表锁数 ... -
mysql分区
2014-02-21 10:38 1800mysql自5.1开始支持分区 ... -
InnoDB 引擎独立表空间 innodb_file_per_table
2013-02-25 11:14 1264http://deeplyloving.iteye.com ... -
mysql监测工具tuning-primer.sh
2013-01-21 17:57 2607【转】http://www.dbasky.net ... -
mysql主从日志的定期清理
2013-01-21 16:24 1115[转]http://wangwei007.blog.51 ... -
[转]Mysql报错:Result consisted of more than one row
2013-01-09 16:25 15784Error Code : 1172 Result consi ... -
根据bin log 分析管理员被莫名删除问题
2013-01-04 17:04 1112============== 根据bin log 分析管理 ... -
mysql中select * for update锁表的问题
2013-01-04 14:07 2473先前介绍过SELECT ... FOR UPDATE的用法 ... -
PDO报错:Cannot execute queries while other unbuffered queries are active.
2012-12-12 17:57 11765用 PDOStatement->execute() 执行 ... -
MySQL死锁导致无法查询
2012-12-11 14:51 2513客服反馈后台无法查询,原因大概知道,是因为MySQL的事务 ... -
mysql性能分析:mysql profiling 应用
2012-12-11 10:26 13051)先打开profiling ==> set pro ... -
mysql体系结构和查看当前的数据库请求
2012-12-07 15:00 2855mysql体系结构: 由 ... -
mysql_error:Error starting thread: Resource temporarily unavailable
2012-11-01 17:57 2064121031 18:53:17 InnoDB: Unable ... -
导出bin log时间段脚本datarecover.sh
2012-09-06 13:34 1182修改 _binlogdir='/data/mysql/m ... -
Mysql备份工具xtraback全量和增量测试
2012-08-17 14:58 3812【转载】http://blog.chinaunix.net/s ... -
数据库中的隔离级别和锁机制
2012-08-09 17:55 1543ANSI/ISO SQL92标准定义了 ... -
mysqldump和mysql命令
2012-08-03 13:44 1342========================= mys ... -
【汇总】mysql join
2012-07-18 11:35 1132标准SQL中CROSS JOIN交叉连接(笛卡尔积)和内连接I ... -
使用innotop监测mysql
2012-07-13 10:56 3772最近学习innotop工具,自己搜集整理了一下网上的各种资源, ...
相关推荐
mysql游标使用的整个过程为: 1.创建游标 代码如下:DECLARE calc_bonus CURSOR FOR SELECT id, salary, commission FROM employees; 2.打开游标 代码如下:OPEN calc_bonus; 3.使用游标 代码如下:FETCH calc_bonus ...
本文实例讲述了MySQL游标概念与用法。分享给大家供大家参考,具体如下: 1、游标的概念(Cursor) 一条sql,对应N条资源,取出资源的接口,就是游标,沿着游标,可以一次取出1行。如果开发过安卓的同学应该知道有一...
BEGIN -- 声明变量 ... /** 声明游标,并将查询结果存到游标中 **/ DECLARE c_borrow CURSOR FOR SELECT ID from rocky_borrow WHERE BORROWTYPE = 2 AND PUBLISH_TIME >= UNIX_TIMESTAMP('2014-
通过ROWCOUNT查看游标指向的行:(隐式游标实例) 例: DECLARE v_count NUMBER; BEGIN SELECT COUNT(*) INTO v_count from dept; --返回一个隐式游标 dbms_output.put_line('SQL%ROWCOUNT = '||SQL%COUNT); END; / ...
本文实例讲述了mysql存储过程之游标(DECLARE)原理与用法。分享给大家供大家参考,具体如下: 我们在处理存储过程中的结果集时,可以使用游标,因为游标允许我们迭代查询返回的一组行,并相应地处理每行。mysql的...
例1、一个简单存储过程游标实例 代码如下: DELIMITER $$ DROP PROCEDURE IF EXISTS getUserInfo $$CREATE PROCEDURE getUserInfo(in date_day datetime)— — 实例— 存储过程名为:getUserInfo— 参数为:date_day...
本文实例讲述了Python操作MySQL数据库的两种方式。分享给大家供大家参考,具体如下: ...cursor=db.cursor()#使用cursor()方法获取操作游标 sql = select * from test0811 cursor.execute(sql) info = cursor.fetchall
本文实例讲述了Python使用pymysql模块操作mysql增删改查。分享给大家供大家参考,具体如下: # -*- coding:utf-8 -*- import pymysql user = input('请输入用户名:') pwd = input('请输入密码:') # 1.连接 conn =...
实例一 import pymysql # 创建连接 # 参数依次对应服务器地址,用户名,密码,数据库 conn = pymysql.connect(host='127.0.0.1', user='root', passwd='123456', db='demo') # 创建游标 cursor = conn.cursor...
本文实例讲述了python针对mysql数据库的连接、查询、更新、删除操作。分享给大家供大家参考,具体如下: 连接 一 代码 import pymysql # 打开数据库连接 db = pymysql.connect(localhost,root,root,db_test01 ) # ...
# 使用 cursor() 方法创建一个游标对象 cursor cursor = db.cursor() # 使用 execute() 方法执行 SQL,如果表存在则删除 cursor.execute("DROP TABLE IF EXISTS EMPLOYEE") # 使用预处理语句创建表
本文为大家分享了Python3.6操作Mysql数据库的具体实例,供大家参考,具体内容如下 安装pymysql 参考https://github.com/PyMySQL/PyMySQL/ pip install pymsql 实例一 import pymysql # 创建连接 # 参数依次对应...
Python的mysql数据库的更新 Python的mysql数据库的更新操作,在实际应用项目中会用到更新...# 使用cursor()方法获取操作游标 cursor = db.cursor() # SQL 更新语句 sql = "UPDATE EMPLOYEE SET AGE = AGE + 1 WHERE S
安装模块 windows:pip install pymysql ubuntu:sudo pip3 install...(3) 创建游标对象 cursor = db.cursor() (4) 准备sql语句 sql = ‘…’ (5) 执行sql语句 cursor.execute(sql) (6) 获取所有结果集 cursor.fetchall()
我就废话不多说了,大家还是直接看代码吧! import pymysql import pandas as pd ...# 创建游标 cursor = db.cursor() cursor.execute(sql) result = cursor.fetchall() #执行结果转化为dataframe df = pd
前言 任何应用都离不开数据,所以在学习python的时候,当然也要学习一个如何用python操作数据库了。MySQLdb就是python对mysql数据库操作的模块。...cursor = conn.cursor()返回一个游标对象 当我们使用cursor.execute
python自2.5版以来,就内置了对sqlite3的支持,使用也非常简单,按照文档上来:复制代码 代码如下:#打开db文件,获得连接conn = sqlite3.connect(‘数据文件名’)#获得游标c = conn.cursor()#执行SQLc.execute(”’...
pymysql 模块! pymysql模块时一个第三方模块!需要下载: pymysql的基本使用: import pymysql conn = pymysql.connect( ...cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)# 产生游标对象 # cursor=py