mysql查詢語句-handler


1 簡介
mysql除可使用select查詢表中的數據,也可使用handler語句,這條語句使我們能夠一行一行的瀏覽一個表中的數據,不過handler語句並不具備select語句的所有功能。它是mysql專用的語句,並沒有包含到SQL標准中。
HANDLER語句提供通往表的直接通道的存儲引擎接口,可以用於MyISAM和InnoDB表。
2 基本語法
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

通過HANDLER tbl_name OPEN打開一張表,無返回結果,實際上我們在這里聲明了一個名為tb1_name的句柄。
通過HANDLER tbl_name READ FIRST獲取句柄的第一行,通過READ NEXT依次獲取其它行。最后一行執行之后再執行NEXT會返回一個空的結果。
通過HANDLER tbl_name CLOSE來關閉打開的句柄。

通過索引去查看的話可以按照一定的順序,獲取表中的數據。
通過HANDLER tbl_name READ index_name FIRST,獲取句柄第一行(索引最小的一行),NEXT獲取下一行,PREV獲取前一行,LAST獲取最后一行(索引最大的一行)。

通過索引列指定一個值,可以指定從哪一行開始。
通過HANDLER tbl_name READ index_name = value,指定從哪一行開始,通過NEXT繼續瀏覽。

3 實例分析

3.1 創建測試表及測試數據

create table handler_table(  
    c1 int,   
    c2 varchar(10),   
    c3 int(10) 
);  
insert into handler_table values(2, 'name2', 002);  
insert into handler_table values(5, 'name5', 005);  
insert into handler_table values(1, 'name1', 001);  
insert into handler_table values(4, 'name4', 004);  
insert into handler_table values(3, 'name3', 003);

3.2 不通過索引打開查看表

打開句柄:

mysql> handler handler_table open;

查看表數據:

mysql> handler handler_table read first;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    2 | name2 |    2 |
+------+-------+------+
mysql> handler handler_table read next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    5 | name5 |    5 |
+------+-------+------+
mysql> handler handler_table read next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    1 | name1 |    1 |
+------+-------+------+
mysql> handler handler_table read next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    4 | name4 |    4 |
+------+-------+------+
mysql> handler handler_table read next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    3 | name3 |    3 |
+------+-------+------+
mysql> handler handler_table read next;
Empty set (0.00 sec)


關閉句柄:

mysql> handler handler_table close;
Query OK, 0 rows affected (0.00 sec)

3.3 通過索引打開查看表(FIRST,NEXT,PREV,LAST)
通過索引查看的話,可以按照索引的升序,從小到大,查看表信息。

創建索引:

mysql> create index handler_index on handler_table(c1);

打開句柄:

mysql> handler handler_table open as p;

查看表數據:

mysql> handler p read handler_index first;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    1 | name1 |    1 |
+------+-------+------+
mysql> handler p read handler_index next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    2 | name2 |    2 |
+------+-------+------+
mysql> handler p read handler_index next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    3 | name3 |    3 |
+------+-------+------+
mysql> handler p read handler_index next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    4 | name4 |    4 |
+------+-------+------+
mysql> handler p read handler_index next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    5 | name5 |    5 |
+------+-------+------+
mysql> handler p read handler_index prev;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    4 | name4 |    4 |
+------+-------+------+
mysql> handler p read handler_index last;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    5 | name5 |    5 |
+------+-------+------+



關閉句柄:

mysql> handler p close;

3.4 通過索引打開查看表(=,<=,>=,<,>)
從index為2的地方開始

打開句柄:

mysql> handler handler_table open as p;

查看表數據:

mysql> handler p read handler_index = (2);
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    2 | name2 |    2 |
+------+-------+------+
mysql> handler p read handler_index next;     
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    3 | name3 |    3 |
+------+-------+------+
mysql> handler p read handler_index next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    4 | name4 |    4 |
+------+-------+------+
mysql> handler p read handler_index next;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    5 | name5 |    5 |
+------+-------+------+
mysql> handler p read handler_index last;
+------+-------+------+
| c1   | c2    | c3   |
+------+-------+------+
|    5 | name5 |    5 |
+------+-------+------+

關閉句柄:

mysql> handler p close;

3.5 附加:語法實例參考

handler handler_table open;
handler handler_table open as p;
handler handler_table read first;
handler handler_table read next;
handler handler_table read first limit 3;
handler handler_table read next limit 3,3;
handler handler_table read first where c1 > 2 limit 2;
handler handler_table read next where c1 >2 limit 1,2;
 
create index handler_index on handler_table(c1);
handler handler_table open;
handler handler_table read handler_index first;
handler handler_table read handler_index next limit 3;
handler handler_table read handler_index PREV limit 3,3;
handler handler_table read handler_index LAST where c1 > 2 limit 2;
handler handler_table read handler_index LAST where c1 > 2 limit 1,2;
handler handler_table read handler_index = (3);
handler handler_table read handler_index <= (3) limit 2;
handler handler_table read handler_index >= (3) limit 1,2;
handler handler_table read handler_index < (4)  where c1 > 0 limit 2;
handler handler_table read handler_index > (1)  where c1 < 6 limit 2,2;
handler handler_table close;
drop index handler_index on handler_table;

4 handler與select的比較

4.1 select語句一次返回所有相關行,handler每次返回一行。
4.2 HANDLER涉及的分析較少,比SELECT更快
4.3 沒有優化程序或查詢校驗開銷
4.4 在兩個管理程序請求之間,不需要鎖定表。

5 注意事項

5.1 如果一個應用停止了,所有仍然打開的句柄將自動停止。
5.2 handler不支持分區表。
5.3 執行TRUNCATE TABLE會關閉所有在該表上打開的handler。
5.4 handler打開一個表時不鎖表,也不對表進行快照,所以當表中數據實時更新時,handler將會失去指針的位置。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM