【MySQL】MySQL 之 handler 的详细使用及说明

起序:在 Web 题遇到的,也算是骚姿势吧,希望帮到有需要的同志。

一、简介

MySQL 除了可以使用 select 查询表中的数据,也可使用 handler 语句,这条语句使我们能够一行一行的浏览一个表中的数据,不过handler 语句并不具备 select 语句的所有功能。它是 MySQL 专用的语句,并没有包含到SQL标准中。handler 语句提供通往表的直接通道的存储引擎接口,可以用于 MyISAMInnoDB 表。

二、语法

1、官方语法

官方给出的:HANDLER Statement

【MySQL】MySQL 之 handler 的详细使用及说明_第1张图片

2、命令分析

句柄:句柄(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

三、实战

1、创建测试表及测试数据

创建表

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;

【MySQL】MySQL 之 handler 的详细使用及说明_第2张图片

2、不通过索引查看表

将会用到的命令:

# 打开一个表名为 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
1、打开句柄
handler handler_table open;

在这里插入图片描述

2、查看数据
handler handler_table read first;
handler handler_table read next;

【MySQL】MySQL 之 handler 的详细使用及说明_第3张图片

3、关闭句柄
handler handler_table close;

在这里插入图片描述


3、通过索引查看表

将会用到的命令:

# 打开一个表名为 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
1、创建索引

handler_table 中的 id 字段创建索引,命名为 handler_index

create index handler_index on handler_table(id);

在这里插入图片描述

2、打开句柄
handler handler_table open;
# 打开句柄并命名为 p
handler handler_table open as p;

在这里插入图片描述

3、查看数据
# 获取第一行数据
handler p read handler_index first;
# 获取下一行数据
handler p read handler_index next;
# 获取上一行数据
handler p read handler_index prev;
# 获取最后一行数据
handler p read handler_index last;

【MySQL】MySQL 之 handler 的详细使用及说明_第4张图片【MySQL】MySQL 之 handler 的详细使用及说明_第5张图片

4、关闭句柄
handler p close;

在这里插入图片描述

4、通过指定索引查看表

将会用到的命令:

# 打开一个表名为 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
1、创建索引

handler_table 中的 id 字段创建索引,命名为 handler_index

ERROR 1061 (42000): Duplicate key name 'handler_index',原因是因为我在 通过索引查看表 这一步已经创建了以 handler_index 命名的索引了。

create index handler_index on handler_table(id);

在这里插入图片描述

2、打开句柄
# 打开句柄并命名为 p
handler handler_table open as p;

在这里插入图片描述

3、查看数据
# 指定索引开始查看数据
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;

【MySQL】MySQL 之 handler 的详细使用及说明_第6张图片

4、关闭句柄
handler p close;

在这里插入图片描述
如果对您有帮助,点个赞再走吧。

你可能感兴趣的:(MySQL)