一、 语法
官方给出的格式:
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。
但作为一个查询技巧,结合自己一定的使用场景,还是值得一试的。
网友评论