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
 The HANDLER statement provides direct access to table storage engine interfaces for key lookups and key or table scans. It is available for at least Aria, Memory (since MariaDB 5.3), MyISAM and InnoDB tables (and should work with most 'normal' storage engines, but not with system tables, MERGE or views).
HANDLER ... OPEN opens a table, allowing it to be accessible to subsequent HANDLER ... READ statements. The table can either be opened using an alias (which must then be used by HANDLER ... READ, or a table name.
The table object is only closed when HANDLER ... CLOSE is called by the session, and is not shared by other sessions.
Starting from MariaDB 5.3 prepared statements work with HANDLER READ, which gives a much higher performance (50% speedup) as there is no parsing and all data is transformed in binary (without conversions to text, as with the normal protocol).
The HANDLER command does not work with partitioned tables.
A key lookup is started with:
HANDLER tbl_name READ index_name { = | >= | <= | < }  (value,value) [LIMIT...]
The values stands for the value of each of the key columns. For most key types (except for HASH keys in MEMORY storage engine) you can use a prefix subset of it's columns.
If you are using LIMIT, then in case of >= or > then there is an implicit NEXT implied, while if you are using <= or < then there is an implicit PREV implied.
After the initial read, you can use
HANDLER tbl_name READ index_name NEXT [ LIMIT ... ] or HANDLER tbl_name READ index_name PREV [ LIMIT ... ]
to scan the rows in key order.
Note that the row order is not defined for keys with duplicated values and will vary from engine to engine.
You can scan a table in key order by doing:
HANDLER tbl_name READ index_name FIRST [ LIMIT ... ] HANDLER tbl_name READ index_name NEXT [ LIMIT ... ]
or, if the handler supports backwards key scans (most do):
HANDLER tbl_name READ index_name LAST [ LIMIT ... ] HANDLER tbl_name READ index_name PREV [ LIMIT ... ]
You can scan a table in row order by doing:
HANDLER tbl_name READ FIRST [ LIMIT ... ] HANDLER tbl_name READ NEXT [ LIMIT ... ]
As this is a direct interface to the storage engine, some limitations may apply for what you can do and what happens if the table changes. Here follows some of the common limitations:
HANDLER READ is not transaction safe, consistent or atomic. It's ok for the storage engine to returns rows that existed when you started the scan but that were later deleted. This can happen as the storage engine may cache rows as part of the scan from a previous read.
You may also find rows committed since the scan originally started.
HANDLER ... READ also reads the data of invisible-columns.
HANDLER ... READ reads everything from system-versioned tables, and so includes row_start and row_end fields, as well as all rows that have since been deleted or changed, including when history partitions are used. 
    © 2019 MariaDB
Licensed under the Creative Commons Attribution 3.0 Unported License and the GNU Free Documentation License.
    https://mariadb.com/kb/en/handler-commands/