MySQL关于HANDLER命令的说明

文章目录

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

一、 语法

官方给出的格式:

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

你可能感兴趣的:(数据库,mysql,java)