精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

面試官:MySQL BETWEEN AND 語句包括邊界嗎?

數據庫 MySQL
使用數據庫時,我們經常會用到范圍查詢,今天來聊一聊?MySQL 的 BETWEEN AND 語句。

使用數據庫時,我們經常會用到范圍查詢,今天來聊一聊 MySQL 的 BETWEEN AND 語句。

1.是否包含邊界

為了說明 BETWEEN AND 語句是否包括邊界,我們先創建一張表,SQL 如下:

CREATE TABLE`test3` (
`id`int(8) NOTNULL AUTO_INCREMENT,
`a`varchar(10) COLLATE utf8_bin DEFAULTNULL,
`b`varchar(10) COLLATE utf8_bin DEFAULTNULL,
`date`dateDEFAULTNULL,
`date_time` datetime DEFAULTNULL,
`time_stamp`timestampNULLDEFAULTNULL,
  PRIMARY KEY (`id`),
KEY`idx_a` (`a`)
) ENGINE=InnoDB AUTO_INCREMENT=11DEFAULTCHARSET=utf8 COLLATE=utf8_bin

我們插入 10 條數據,如下圖:

圖片圖片

圖片圖片

1.1 執行結果

  • 對 id 做范圍查詢
SELECT * FROM test3 WHERE id BETWEEN 2 AND 6;

查詢結果如下:

圖片圖片

圖片圖片

可以看到,對 id 做范圍查詢,包含了邊界值 2 和 6,是一個閉區間。

  • 對 date 做范圍查詢
SELECT * FROM test3 WHERE DATE BETWEEN '2025-08-28' AND '2025-08-31';

查詢結果如下:

圖片圖片

圖片圖片

可以看到,對 date 類型的字段進行范圍查詢,同樣包含了邊界值,是一個閉區間。

  • 對 date_time 做范圍查詢
SELECT * FROM test3 WHERE date_time BETWEEN '2025-08-28' AND '2025-08-31';

對 date_time 使用日期做范圍查詢,查詢結果如下:

圖片圖片

圖片圖片

可以看到,這個查詢漏掉了 2025-08-31 這一天的數據,是一個前閉后開的區間。

這是因為 MySQL 會自動將日期的時間部分補充為零點,所以上面的查詢語句等價于:

SELECT * FROM test3 WHERE date_time BETWEEN '2025-08-28 00:00:00' AND '2025-08-31 00:00:00';

為了不漏掉數據,可以將上面的查詢語句改為:

SELECT * FROM test3 WHERE DATE BETWEEN '2025-08-28' AND '2025-09-01';

對 time_stamp 使用日期做范圍查詢,結果跟 date_time 一樣。

1.2 總結

  • BETWEEN AND 語句是包括邊界值的,是一個前閉后閉的區間。BETWEEN A AND B 等價于 >= A AND <= B。
  • 注意時間類型的字段,DATETIME 和 TIMESTAMP,如果采用日期格式來查詢,結果是前閉后開的區間。BETWEEN A AND B 等價于 >= A AND < B。為了避免漏掉數據,datetime 和 timestamp 使用日期做范圍查詢,可以在后面的日期上加 1 天。

2.原理

2.1 執行器優化

對于 BETWEEN AND 語句,MySQL 優化器會在早期優化時把它優化成等值查詢,所以下面查詢 SQL

SELECT * FROM test3 WHERE id BETWEEN 2 AND 6;

在優化器看來完全等價與:

SELECT * FROM test3 WHERE id >= 2 AND id <= 6;

兩個 SQL 在性能上沒有差別。

2.2 性能

索引范圍掃描

如果 BETWEEN AND 語句的字段上有索引,則可以使用索引進行范圍掃描,效率很高。我們看一下上面一個 SQL 執行計劃如下:

EXPLAIN SELECT * FROM test3 WHERE id BETWEEN 2 AND 6;

圖片圖片

圖片圖片

type=range,代碼使用到了索引進行范圍掃描,查詢過程如下:

  1. 存儲引擎從索引樹的根節點開始,找到第一個 id >= 2 的索引條目。這個操作時間復雜度是 O(log n),非常高效;
  2. 從上面找到的第一個索引條目開始,沿著索引樹的葉子節點向后順序掃描;
  3. 當遇到第一個 id > 6 的索引條目時,停止掃描;
  4. 存儲引擎給執行器返回結果集。

全表掃描

如果 BETWEEN AND 語句的字段上沒有索引,只能進行全表掃描,比如下面的語句:

EXPLAIN SELECT * FROM test3 WHERE b BETWEEN 30 AND 50;

我們看一下執行計劃:

圖片圖片

圖片圖片

這就需要掃描表中的每一行記錄,逐一判斷字段 b 的值是否落在 [30, 50] 這個區間內。這個執行效率非常低。

非主鍵索引跟等值查詢不同的是,即使 BETWEEN AND 語句的字段加了普通索引,如果查詢的字段用不上覆蓋索引,也會走全表掃描。如下面的語句:

EXPLAIN SELECT * FROM test3 WHERE a BETWEEN 30 AND 50;

雖然字段 a 上面有普通索引,但是查詢的是表 test3 中的所有字段,也是走不上 a 這個索引的。我們看一下執行計劃:

圖片圖片

復合索引

我們再看一下復合索引的情況,我們新建一張表,SQL 如下:

CREATE TABLE`test4` (
`id`int(8) NOTNULL AUTO_INCREMENT,
`a`varchar(10) COLLATE utf8_bin DEFAULTNULL,
`b`varchar(10) COLLATE utf8_bin DEFAULTNULL,
`date`dateDEFAULTNULL,
`date_time` datetime DEFAULTNULL,
`time_stamp`timestampNULLDEFAULTNULL,
  PRIMARY KEY (`id`),
KEY`idx_a_b` (`a`, `b`)
) ENGINE=InnoDB AUTO_INCREMENT=11DEFAULTCHARSET=utf8 COLLATE=utf8_bin

在 test4 這張表上,我們建一個字段(a,b)的復合索引。 BETWEEN AND 語句是可以用最左前綴原則的。如果我們執行下面 SQL:

SELECT a,b,id FROM test4 WHERE a BETWEEN 2 AND 6 AND b = 3;

復合索引的第一列 a 使用了范圍查詢,第二列 b 作等值查詢。MySQL 可以利用索引快速找到字段 a 在范圍[2, 6]之間的數據,然后在這些結果中篩選出 b = 3 的記錄。這種情況下字段 a 使用了索引,但是字段 b 沒有用上索引。

圖片圖片

如果我們執行下面 SQL:

SELECT a,b,id FROM test4 WHERE a = 3 and b BETWEEN 2 AND 6;

復合索引的第一列 a 使用了等值查詢,第二列 b 做范圍查詢。這種情況也是可以走上索引的。

圖片圖片

如果我們執行下面 SQL:

SELECT a,b,id FROM test4 WHERE b BETWEEN 2 AND 6;

這種情況不符合最左前綴原則,所以是走不上索引的。

圖片圖片

索引下推

使用 BETWEEN AND 語句不能走索引下推。

我們再來創建一張表:

CREATE TABLE`test_temp` (
`id`INT(11) NOTNULLDEFAULT'0',
`a`VARCHAR(20) DEFAULTNULL,
`b`VARCHAR(10) DEFAULTNULL,
`c`VARCHAR(10) DEFAULTNULL,
`d`VARCHAR(10) DEFAULTNULL,
  PRIMARY KEY (`id`),
KEY`a_b`(`a`,`b`)
) ENGINE=INNODBDEFAULTCHARSET=utf8

插入幾條數據

INSERT INTO test_temp VALUES(100, 10, 20, 2, 1);
INSERT INTO test_temp VALUES(200, 10, 40, 4, 2);
INSERT INTO test_temp VALUES(300, 10, 30, 3, 3);
INSERT INTO test_temp VALUES(400, 40, 10, 1, 4);

如果我們執行下面的 SQL,是不能走索引下推的:

EXPLAIN SELECT * FROM test_temp WHERE a BETWEEN '10' AND '50' AND b < '50';

執行計劃如下:


圖片圖片

圖片圖片

而如果我們把 SQL 改成:

EXPLAIN SELECT * FROM test_temp WHERE a >= '10' AND a <=  '50' AND b < '50';

執行計劃如下:

圖片圖片

圖片圖片

可以看到,用上了索引下推。

3 總結

本文介紹了 BETWEEN AND 語句的用法、原理和性能,希望對你理解這個范圍查詢語句有所幫助 。


責任編輯:武曉燕 來源: 君哥聊技術
相關推薦

2025-10-09 01:11:00

2025-10-31 02:00:00

2022-08-02 06:31:32

Java并發工具類

2022-07-26 08:40:42

Java并發工具類

2025-03-26 01:25:00

MySQL優化事務

2022-05-23 08:43:02

BigIntJavaScript內置對象

2021-01-06 17:28:00

MySQL數據庫緩存池

2022-06-30 08:14:05

Java阻塞隊列

2025-06-30 01:55:00

2022-07-11 10:47:46

容器JAVA

2015-08-13 10:29:12

面試面試官

2019-10-21 09:56:37

MySQLCOUNTInnoDB

2020-03-06 15:36:01

Redis內存宕機

2024-10-16 15:01:20

2024-07-22 14:09:22

@AsyncJava

2022-07-15 08:22:42

對象符串鍵Symbol

2021-09-08 08:06:57

Redis原子性數據類型

2024-01-10 15:27:58

SessionCookieWeb 應用

2021-04-12 21:34:29

Redis故障數據

2023-02-16 08:10:40

死鎖線程
點贊
收藏

51CTO技術棧公眾號

精品电影一区二区| 一区二区在线看| 国产精品香蕉av| 青娱乐91视频| 国产精品中文字幕亚洲欧美| 欧美日本在线播放| 日本中文字幕网址| 日本三级视频在线观看| 福利一区在线观看| 国产精品爱久久久久久久| 美女视频久久久| 人人网欧美视频| 欧美一区三区二区| 午夜激情福利在线| 黄色在线看片| 成人免费一区二区三区视频| 精品不卡在线| 国产强伦人妻毛片| 日韩二区在线观看| 久久久久久久久久婷婷| 久久成人小视频| 伊人成综合网yiren22| 日韩一区二区电影在线| 91最新在线观看| 午夜av不卡| 亚洲已满18点击进入久久| 亚洲高清视频一区| 日本aaa在线观看| 国产不卡视频在线观看| 成人黄色av网站| 成人黄色免费网| 蜜桃av一区| 午夜精品福利在线观看| 亚洲一级生活片| 日韩欧美精品综合| 亚洲午夜未满十八勿入免费观看全集| 久久精品aⅴ无码中文字字幕重口| 久久99久久久精品欧美| 色婷婷av久久久久久久| 男人和女人啪啪网站| 伦理在线一区| 亚洲一区二区视频| 欧美视频在线第一页| 成人欧美在线| 亚洲同性同志一二三专区| 亚洲bbw性色大片| 国家队第一季免费高清在线观看| 91一区在线观看| 国产精品三区www17con| 你懂的网站在线| 成人国产精品免费观看视频| 成人在线看片| 日本免费不卡视频| 99久久久无码国产精品| 久久国产精品-国产精品| 日韩一级在线播放| 94色蜜桃网一区二区三区| 精品午夜一区二区| 你懂的在线观看| 欧美极品美女视频| 亚洲一区二区三区精品视频| 天堂а√在线资源在线| 国产精品久久久久久亚洲伦| 亚洲欧美丝袜| 成人av福利| 亚洲一二三四区| 日日碰狠狠添天天爽超碰97| 无码小电影在线观看网站免费| 日韩欧美a级成人黄色| 欧在线一二三四区| 色诱色偷偷久久综合| 欧美一区二区视频免费观看| 日本xxxx免费| 日韩高清三区| 亚洲午夜未满十八勿入免费观看全集| 69xxx免费| 中文字幕日韩欧美精品高清在线| 欧美成人在线免费视频| 日韩欧美激情视频| 日本中文字幕一区二区有限公司| 国产精品一二区| www.欧美国产| 26uuu国产在线精品一区二区| 日本一区二区免费看| 无遮挡动作视频在线观看免费入口| gay欧美网站| 91精品综合| 色综合久久久久久中文网| 日韩精品成人在线| 美国欧美日韩国产在线播放| www 成人av com| 清纯唯美亚洲色图| 亚洲人精品午夜| 久久久999免费视频| 欧美aaaaaa| 亚洲精品国产精品自产a区红杏吧 亚洲精品国产精品乱码不99按摩 亚洲精品国产精品久久清纯直播 亚洲精品国产精品国自产在线 | 亚洲成人av一区二区三区| 国产三区在线视频| 国产视频一区二区在线播放| 亚洲激情视频在线观看| 欧美手机在线观看| 久久动漫亚洲| 波多野结衣一区二区三区在线观看| 深夜福利免费在线观看| 亚洲三级理论片| 国产日韩一区二区在线观看| 粉嫩av国产一区二区三区| 亚洲免费人成在线视频观看| 青花影视在线观看免费高清| 亚洲欧美日本国产专区一区| 91成人伦理在线电影| av免费在线一区二区三区| 亚洲成人免费电影| 超碰人人草人人| 精品国产91乱码一区二区三区四区| 久久777国产线看观看精品| 天天干天天色综合| 99r国产精品| 国内自拍中文字幕| 日韩黄色三级| 一本色道久久综合狠狠躁篇的优点 | 国内自拍视频一区二区三区| 国产精品视频久久久| 亚洲人成色777777精品音频| 亚洲精品国产a久久久久久| 九色91popny| 精品中文字幕一区二区三区av| 欧美日本国产在线| 国产精品伦理一区| 国产女主播视频一区二区| 国产精品―色哟哟| 国产精品区一区二区三在线播放| 在线视频婷婷| 欧日韩精品视频| 3d动漫精品啪啪一区二区下载| 亚洲午夜精品久久久久久app| 91性高湖久久久久久久久_久久99| sese一区| 欧美少妇xxx| 亚洲欧美日韩第一页| 日韩国产欧美一区二区三区| 欧美一区二视频在线免费观看| xxxx在线视频| 欧美精品一区二区在线播放| 精品无码黑人又粗又大又长| 国产99久久久国产精品潘金| 国产免费一区二区三区四在线播放| 国产美女久久| 久久久黄色av| www.97超碰| 亚洲自拍偷拍网站| 高清中文字幕mv的电影| 亚洲高清激情| 久久艹中文字幕| 成人av观看| 亚洲性夜色噜噜噜7777| 自拍偷拍精品视频| 中文字幕一区二区三区色视频| 国产精品v日韩精品v在线观看| 999精品色在线播放| 国产日韩欧美日韩大片| 最新国产露脸在线观看| 亚洲国产精品系列| 亚洲天堂视频网站| 国产欧美日韩在线| 中文字幕在线观看日| 中国精品18videos性欧美| 91嫩草在线| 在线高清av| 色av吧综合网| 精品国产av一区二区三区| 亚洲一二三区视频在线观看| 97精品人妻一区二区三区蜜桃| 国产欧美成人| 亚洲精品一区国产精品| 麻豆国产精品| 热99久久精品| 好了av在线| 精品999在线播放| 国产免费一区二区三区四区五区| 国产精品久久777777| 潘金莲一级淫片aaaaa| 亚洲一区二区三区四区五区午夜| 午夜免费电影一区在线观看| 国产欧美88| 欧美做受高潮电影o| 在线观看麻豆| 亚洲国产三级网| 无码人妻熟妇av又粗又大 | 久久久久久久久久97| 大胆亚洲人体视频| 亚洲欧美国产日韩综合| 国产精品xvideos88| 欧美一级二级三级九九九| 亚洲人成网站在线在线观看| 97视频在线播放| 欧美成人高清在线| 亚洲欧美成人精品| 性生活视频软件| 欧美在线免费视屏| 日韩免费一二三区| 国产精品色噜噜| 粉嫩av懂色av蜜臀av分享| 久久精品久久久精品美女| 妞干网在线观看视频| 日韩片欧美片| 久久亚洲精品欧美| 99香蕉久久| 国产日韩欧美91| 欧美最新精品| 97精品在线视频| av免费网站在线观看| 中文字幕亚洲字幕| 四虎精品成人影院观看地址| 日韩免费成人网| 一区二区美女视频| 在线观看亚洲一区| av一级在线观看| 欧美日韩国产精品专区| 免费毛片在线播放免费| 一区在线观看视频| 成人在线观看免费高清| 91老师国产黑色丝袜在线| 中文在线字幕观看| 国产一区二区三区在线观看精品| 91看片就是不一样| 亚洲综合99| av免费观看国产| 亚洲成色精品| 欧美高清中文字幕| 欧美日本国产| 肉大捧一出免费观看网站在线播放| 日韩一区自拍| 亚洲欧美成人一区| 日韩精品免费一区二区三区| 日本高清一区| 精品国产乱码久久久| 欧美三级华人主播| 精品不卡一区| 无码免费一区二区三区免费播放| av伊人久久| 亚欧精品在线| 图片小说视频色综合| 杨幂一区欧美专区| 香蕉av一区二区| 亚洲精品少妇一区二区| 在线观看国产精品入口| 国产人妻人伦精品| 午夜欧美视频| 黄色大片中文字幕| 亚洲视频成人| 久草福利视频在线| 久久精品72免费观看| 九一精品久久久| 国产成人在线观看免费网站| 深夜视频在线观看| 99国产精品久| 久久久久久成人网| 亚洲免费三区一区二区| 久久久久久久久久一区二区三区| 亚洲一区二区3| 91精品国产综合久久久蜜臀九色| 色伊人久久综合中文字幕| 中文亚洲av片在线观看| 在线不卡中文字幕| www.日本在线观看| 精品网站999www| 尤物网在线观看| 久久成人免费视频| 欧美gv在线| 国产精品专区h在线观看| 日本精品视频| 久久久精品动漫| 日韩欧美在线中字| 日本黄色片一级片| 日韩福利电影在线| 国产亚洲色婷婷久久| 91麻豆国产在线观看| 久久一级免费视频| 亚洲国产精品欧美一二99| 欧美国产成人精品一区二区三区 | 超碰在线观看av| 亚洲第一视频在线观看| 国产污视频在线| 欧美www在线| 亚洲欧美se| 亚洲v日韩v综合v精品v| 日本一道高清一区二区三区| 亚洲精品国产精品久久| 亚洲国产一区二区精品专区| 手机视频在线观看| 成人精品鲁一区一区二区| 亚洲国产日韩一区无码精品久久久| 亚洲三级理论片| 国产一级淫片a视频免费观看| 欧美一区二区成人6969| 欧美扣逼视频| 久久91超碰青草是什么| 日本精品另类| 国产欧美日韩一区二区三区| 色综合狠狠操| a√天堂在线观看| 国产精品白丝av| 国产精品成人在线视频| 亚洲va欧美va天堂v国产综合| 国产无遮挡又黄又爽又色视频| 日韩精品资源二区在线| 国产精品一区二区婷婷| 国内自拍欧美激情| 精品三级久久久| 一区二区精品视频| 丝袜诱惑制服诱惑色一区在线观看| 性生交大片免费看l| 中文字幕av不卡| 日韩在线一区二区三区免费视频| 午夜不卡视频| 国产精品扒开腿做爽爽爽视频| 国产三级精品三级在线观看国产| 宅男噜噜99国产精品观看免费| 性娇小13――14欧美| 午夜剧场免费看| 亚洲综合色网站| 99热这里只有精品在线| 色偷偷噜噜噜亚洲男人的天堂| 欧美电影免费观看高清完整| 国内成+人亚洲| 亚洲美女网站| 欧美极品jizzhd欧美仙踪林| 亚洲免费av高清| 91亚洲国产成人精品一区| 中文字幕久久亚洲| 姬川优奈av一区二区在线电影| 精品麻豆av| 国产视频一区在线观看一区免费| 一区二区在线免费观看视频| 亚洲视频免费在线观看| 国产麻豆一精品一男同| 日韩一级黄色av| 国产精品99| 午夜老司机精品| 美国十次了思思久久精品导航 | 国产成人无码www免费视频播放| 日韩有码在线观看| 91成人福利社区| 热这里只有精品| 国产乱子轮精品视频| 亚洲精品卡一卡二| 欧美一区二区三区视频免费播放 | 精品国产乱码久久久久久天美| 刘亦菲毛片一区二区三区| 久久免费少妇高潮久久精品99| 波多野结衣在线一区二区| av女优在线播放| 97久久超碰国产精品| 午夜精品一区二| 日韩在线免费视频观看| 亚洲人成777| 99久久久精品视频| 波多野结衣91| 国内自拍视频在线播放| 在线观看欧美日韩| av成人在线网站| 日本最新高清不卡中文字幕| 黄色污污视频软件| 亚洲精品二三区| 毛片免费看不卡网站| 色一情一乱一伦一区二区三欧美| 蜜臀国产一区二区三区在线播放| 免费国产羞羞网站美图| 精品国产免费视频| 中文av在线全新| 一本色道久久综合亚洲二区三区| 国内成人精品2018免费看| 一区二区三区免费高清视频| 日韩电影免费在线观看中文字幕 | 性久久久久久久久久久| 日本道色综合久久| 免费观看在线黄色网| 国产精品久久久久免费| 日韩av网站在线观看| 国精产品一区一区二区三区mba| 日韩免费高清av| 国产日韩另类视频一区| 一本二本三本亚洲码| 久久这里只有精品6| 国产视频在线免费观看| 欧美影院在线播放| 91精品国产91久久久久久黑人| 亚洲av无码一区二区三区网址 | 国产免费无码一区二区| 色综合中文字幕国产| 久草免费在线| 久久久www免费人成黑人精品| 精品一区二区在线播放| 国产一区二区99| 欧美久久久精品| 欧美日韩国产一区二区三区不卡| 成人一区二区三区仙踪林| 欧美性猛交xxxx黑人交| 色戒汤唯在线观看|