MySQL关于HANDLER命令的说明

一、 语法

官方给出的格式:

HANDLER tbl_name OPEN [ [AS] alias]

HANDLER tbl_name READ index_name { = | <= | >= | < | > } (value1,value2,...)
    [ WHERE where_condition ] [LIMIT ... ]
HANDLER tbl_name READ index_name { FIRST | NEXT | PREV | LAST }
    [ WHERE where_condition ] [LIMIT ... ]
HANDLER tbl_name READ { FIRST | NEXT }
    [ WHERE where_condition ] [LIMIT ... ]

HANDLER tbl_name CLOSE 

假设有一张表叫’user’,有一列叫’name’,该列有一个索引叫’name_index’,如果要查询name为小明的记录,那么HANDLER语句的写法就是:

handler user open as user;
handler user READ name_index=('小明') ;

handler user close;

需要注意的是,这个语句只会返回一条记录(如果表中有满足条件的记录),如果要返回多条,可以这么写:

handler user open as user;
handler user READ name_index=('小明') limit 10 ;

handler user close;

但是依旧有一个问题:我们没办法一次返回所有的记录——因为我们并不知道满足条件的记录一共有多少条。

二、为什么要用HANDLER而不是“SELECT”语句

官方的说法是:

HANDLER查询性能比SELECT更好

但从上面我们也能看出,HANDLER的使用场景比起SELECT来说要少的多(它也不支持分区表),毕竟HANDLER is a somewhat low-level statement。
但作为一个查询技巧,结合自己一定的使用场景,还是值得一试的。
[1]: https://dev.mysql.com/doc/refman/5.6/en/handler.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值