起序:在 Web
题遇到的,也算是骚姿势吧,希望帮到有需要的同志。
MySQL
除了可以使用 select
查询表中的数据,也可使用 handler
语句,这条语句使我们能够一行一行的浏览一个表中的数据,不过handler
语句并不具备 select
语句的所有功能。它是 MySQL
专用的语句,并没有包含到SQL标准中。handler
语句提供通往表的直接通道的存储引擎接口,可以用于 MyISAM
和 InnoDB
表。
官方给出的:HANDLER Statement
句柄:句柄(Handle)是一个是用来标识对象或者项目的标识符,可以用来描述窗体、文件等。这是我从百度上搜到的。
翻译成白话就是,
句柄
相当于一个指针,是一个广义的指针,不是特定指向某一个形式(整数、数组、对象等)。
# 打开一个表名为 tbl_name 的表的句柄
HANDLER tbl_name OPEN [ [AS] alias]
# 1、通过指定索引查看表,可以指定从索引那一行开始,通过 NEXT 继续浏览
HANDLER tbl_name READ index_name { = | <= | >= | < | > } (value1,value2,...)
[ WHERE where_condition ] [LIMIT ... ]
# 2、通过索引查看表
# FIRST: 获取第一行(索引最小的一行)
# NEXT: 获取下一行
# PREV: 获取上一行
# LAST: 获取最后一行(索引最大的一行)
HANDLER tbl_name READ index_name { FIRST | NEXT | PREV | LAST }
[ WHERE where_condition ] [LIMIT ... ]
# 3、不通过索引查看表
# READ FIRST: 获取句柄的第一行
# READ NEXT: 依次获取其他行(当然也可以在获取句柄后直接使用获取第一行)
# 最后一行执行之后再执行 READ NEXT 会返回一个空的结果
HANDLER tbl_name READ { FIRST | NEXT }
[ WHERE where_condition ] [LIMIT ... ]
# 关闭已打开的句柄
HANDLER tbl_name CLOSE
创建表
create table handler_table(id int, name varchar(10));
按下列顺序依次插入数据
insert into handler_table values(3, '张三');
insert into handler_table values(4, '李四');
insert into handler_table values(5, '王五');
insert into handler_table values(1, '刘一');
insert into handler_table values(2, '陈二');
查看数据
select *from handler_table;
将会用到的命令:
# 打开一个表名为 tbl_name 的表的句柄
HANDLER tbl_name OPEN [ [AS] alias]
# READ FIRST: 获取句柄的第一行
# READ NEXT: 依次获取其他行(当然也可以在获取句柄后直接使用获取第一行)
# 最后一行执行之后再执行 READ NEXT 会返回一个空的结果
HANDLER tbl_name READ { FIRST | NEXT }
[ WHERE where_condition ] [LIMIT ... ]
# 关闭以打开的句柄
HANDLER tbl_name CLOSE
handler handler_table open;
handler handler_table read first;
handler handler_table read next;
handler handler_table close;
将会用到的命令:
# 打开一个表名为 tbl_name 的表的句柄
HANDLER tbl_name OPEN [ [AS] alias]
# 2、通过索引查看表
# FIRST: 获取第一行(索引最小的一行)
# NEXT: 获取下一行
# PREV: 获取上一行
# LAST: 获取最后一行(索引最大的一行)
HANDLER tbl_name READ index_name { FIRST | NEXT | PREV | LAST }
[ WHERE where_condition ] [LIMIT ... ]
# 关闭以打开的句柄
HANDLER tbl_name CLOSE
以
handler_table
中的id
字段创建索引,命名为handler_index
。
create index handler_index on handler_table(id);
handler handler_table open;
# 打开句柄并命名为 p
handler handler_table open as p;
# 获取第一行数据
handler p read handler_index first;
# 获取下一行数据
handler p read handler_index next;
# 获取上一行数据
handler p read handler_index prev;
# 获取最后一行数据
handler p read handler_index last;
handler p close;
将会用到的命令:
# 打开一个表名为 tbl_name 的表的句柄
HANDLER tbl_name OPEN [ [AS] alias]
# 1、通过指定索引查看表,可以指定从索引那一行开始,通过 NEXT 继续浏览
HANDLER tbl_name READ index_name { = | <= | >= | < | > } (value1,value2,...)
[ WHERE where_condition ] [LIMIT ... ]
# 关闭以打开的句柄
HANDLER tbl_name CLOSE
以
handler_table
中的id
字段创建索引,命名为handler_index
。
ERROR 1061 (42000): Duplicate key name 'handler_index'
,原因是因为我在通过索引查看表
这一步已经创建了以handler_index
命名的索引了。
create index handler_index on handler_table(id);
# 打开句柄并命名为 p
handler handler_table open as p;
# 指定索引开始查看数据
handler p read handler_index = (2);
# -------------------- #
# 也可以继续使用下面的命令 #
# -------------------- #
# 获取第一行数据
handler p read handler_index first;
# 获取下一行数据
handler p read handler_index next;
# 获取上一行数据
handler p read handler_index prev;
# 获取最后一行数据
handler p read handler_index last;
handler p close;