日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

查看MySQL句柄_mysql查询语句-handler

發(fā)布時(shí)間:2025/3/20 数据库 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 查看MySQL句柄_mysql查询语句-handler 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1 簡(jiǎn)介

mysql除可使用select查詢表中的數(shù)據(jù),也可使用handler語(yǔ)句,這條語(yǔ)句使我們能夠一行一行的瀏覽一個(gè)表中的數(shù)據(jù),不過(guò)handler語(yǔ)句并不具備select語(yǔ)句的所有功能。它是mysql專用的語(yǔ)句,并沒(méi)有包含到SQL標(biāo)準(zhǔn)中。

HANDLER語(yǔ)句提供通往表的直接通道的存儲(chǔ)引擎接口,可以用于MyISAM和InnoDB表。

2 基本語(yǔ)法

handler語(yǔ)句的語(yǔ)法如下:

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

通過(guò)HANDLER tbl_name OPEN打開一張表,無(wú)返回結(jié)果,實(shí)際上我們?cè)谶@里聲明了一個(gè)名為tb1_name的句柄。

通過(guò)HANDLER tbl_name READ FIRST獲取句柄的第一行,通過(guò)READ NEXT依次獲取其它行。最后一行執(zhí)行之后再執(zhí)行NEXT會(huì)返回一個(gè)空的結(jié)果。

通過(guò)HANDLER tbl_name CLOSE來(lái)關(guān)閉打開的句柄。

通過(guò)索引去查看的話可以按照一定的順序,獲取表中的數(shù)據(jù)。

通過(guò)HANDLER tbl_name READ index_name FIRST,獲取句柄第一行(索引最小的一行),NEXT獲取下一行,PREV獲取前一行,LAST獲取最后一行(索引最大的一行)。

通過(guò)索引列指定一個(gè)值,可以指定從哪一行開始。

通過(guò)HANDLER tbl_name READ index_name = value,指定從哪一行開始,通過(guò)NEXT繼續(xù)瀏覽。

3 實(shí)例分析

3.1 創(chuàng)建測(cè)試表及測(cè)試數(shù)據(jù)

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 不通過(guò)索引打開查看表

打開句柄:

mysql> handler handler_table open;

查看表數(shù)據(jù):

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)

關(guān)閉句柄:

mysql> handler handler_table close;

Query OK, 0 rows affected (0.00 sec)

3.3 通過(guò)索引打開查看表(FIRST,NEXT,PREV,LAST)

通過(guò)索引查看的話,可以按照索引的升序,從小到大,查看表信息。

創(chuàng)建索引:

mysql> create index handler_index on handler_table(c1);

打開句柄:

mysql> handler handler_table open as p;

查看表數(shù)據(jù):

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 |

+------+-------+------+

關(guān)閉句柄:

mysql> handler p close;

3.4 通過(guò)索引打開查看表(=,<=,>=,)

從index為2的地方開始

打開句柄:

mysql> handler handler_table open as p;

查看表數(shù)據(jù):

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 |

+------+-------+------+

關(guān)閉句柄:

mysql> handler p close;

3.5 附加:語(yǔ)法實(shí)例參考

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語(yǔ)句一次返回所有相關(guān)行,handler每次返回一行。

4.2 HANDLER涉及的分析較少,比SELECT更快

4.3 沒(méi)有優(yōu)化程序或查詢校驗(yàn)開銷

4.4 在兩個(gè)管理程序請(qǐng)求之間,不需要鎖定表。

5 注意事項(xiàng)

5.1 如果一個(gè)應(yīng)用停止了,所有仍然打開的句柄將自動(dòng)停止。

5.2 handler不支持分區(qū)表。

5.3 執(zhí)行TRUNCATE TABLE會(huì)關(guān)閉所有在該表上打開的handler。

5.4 handler打開一個(gè)表時(shí)不鎖表,也不對(duì)表進(jìn)行快照,所以當(dāng)表中數(shù)據(jù)實(shí)時(shí)更新時(shí),handler將會(huì)失去指針的位置。

與50位技術(shù)專家面對(duì)面20年技術(shù)見(jiàn)證,附贈(zèng)技術(shù)全景圖

總結(jié)

以上是生活随笔為你收集整理的查看MySQL句柄_mysql查询语句-handler的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。