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

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

一、简介

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

二、语法

1、官方语法

官方给出的:HANDLER Statement

在这里插入图片描述

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;

在这里插入图片描述

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;

在这里插入图片描述

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;

在这里插入图片描述在这里插入图片描述

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;

在这里插入图片描述

4、关闭句柄
handler p close;

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

  • 38
    点赞
  • 63
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
MySQL中,CONTINUE HANDLER是一种错误处理机制,用于在存储过程或函数中捕获并处理异常。它允许我们在出现异常时继续执行后续的语句,而不是立即中断程序的执行。 CONTINUE HANDLER的用法如下: 1. 定义CONTINUE HANDLER:在存储过程或函数的BEGIN...END语句块内,使用DECLARE CONTINUE HANDLER语句定义一个异常处理器。 ```sql DECLARE <condition> HANDLER FOR <exception> BEGIN -- 异常处理逻辑 END; ``` 这里,`<condition>` 是一个局部变量,可用于在异常处理程序中获取异常的详细信息;`<exception>` 是指定要捕获的异常类型。 2. 编写异常处理逻辑:在 `BEGIN...END` 语句块内编写异常处理逻辑,以处理指定类型的异常。可以在异常处理程序中执行需要的操作,如记录日志、回滚事务、输出错误消息等。 ```sql DECLARE CONTINUE HANDLER FOR SQLEXCEPTION BEGIN -- 异常处理逻辑 END; ``` 在上面的示例中,我们使用 `SQLEXCEPTION` 来捕获任何SQL异常。 3. 使用CONTINUE HANDLER:在存储过程或函数的执行过程中,当发生指定类型的异常时,CONTINUE HANDLER会被触发,并执行相应的异常处理逻辑。 ```sql BEGIN -- 执行语句 -- ... END; ``` 当在 `BEGIN...END` 语句块内出现异常时,异常处理程序会被调用,然后程序会继续执行后续的语句。 需要注意的是,CONTINUE HANDLER只能捕获指定类型的异常,并且只能在存储过程或函数中使用。它不能用于触发器或其他类型的SQL语句中。 以上是CONTINUE HANDLER的基本用法。通过使用CONTINUE HANDLER,我们可以更好地控制程序的执行流程,在出现异常时进行适当的处理,而不会导致整个程序的中断。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

边扯边淡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值