欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL BETWEEN AND踩坑記錄

 更新時(shí)間:2023年07月28日 11:02:18   作者:Bryce180  
這篇文章主要介紹了MySQL BETWEEN AND踩坑記錄,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

MySQL BETWEEN AND踩坑

在日常使用MySQL的過程中,我們很習(xí)慣性的會(huì)使用“BETWEEN … AND…”來(lái)進(jìn)行條件查詢,篩選對(duì)應(yīng)時(shí)間、狀態(tài)的數(shù)據(jù)。

但,如果這個(gè)日期字段是日期/時(shí)間格式,那么坑就來(lái)了。

SELECT 
	* # 正式學(xué)習(xí)工作盡量不要直接使用 *,這里是自建的模擬表無(wú)所謂
FROM 
	test 
WHERE 
	time BETWEEN '2023-04-01' AND '2023-04-20'
ORDER BY 
	time desc

輸出結(jié)果:

在這里插入圖片描述

但是!

實(shí)際上我們的表中是有2023-04-20這一天的數(shù)據(jù)的

SELECT 
	*
FROM 
	test 
WHERE 
	DATE(time) = '2023-04-20'

在這里插入圖片描述

MySQL的BETWEEN ... AND...的取值確實(shí)是閉區(qū)間,但是如果日期字段包含時(shí)間,即2023-04-20 09:23:35

MySQL會(huì)將BETWEEN '2023-04-01' AND '2023-04-20'自動(dòng)轉(zhuǎn)換為BETWEEN '2023-04-01 00:00:00' AND '2023-04-20 00:00:00'

也就是說,當(dāng)日期字段帶時(shí)間時(shí),最后一天僅會(huì)獲取00:00:00這一時(shí)間點(diǎn)的數(shù)據(jù),而非我們想象中的最后一天一整天的數(shù)據(jù)!

解決思路

1.使用DATE()

DATE(time) BETWEEN '2023-04-01' AND '2023-04-20'

2.使用小于號(hào),小于最后一天的后一天

time >= '2023-04-01' and time < '2023-04-21'

3.手動(dòng)補(bǔ)上時(shí)間(不建議,麻煩且可能出現(xiàn)更多坑)

time BETWEEN '2023-04-01 00:00:00.000000' AND '2023-04-20 23:59:59.999999'

MySQL之between ...and....小知識(shí)點(diǎn)

使用BETWEEN AND關(guān)鍵字檢索數(shù)據(jù)表中指定的數(shù)據(jù)內(nèi)容。

帶BETWEEN AND關(guān)鍵字的查詢

我們已經(jīng)學(xué)會(huì)了如何用IN關(guān)鍵字精確查詢數(shù)據(jù)表中的內(nèi)容,但是在很多時(shí)候,我們僅僅是想知道在某一范圍內(nèi)有多少符合條件的數(shù)據(jù),這就不得不使用到關(guān)鍵字BETWEEN AND了,它是閉區(qū)間,前后都可以取到。

BETWEEN AND需要兩個(gè)參數(shù)支持,一個(gè)是范圍的開始值,另一個(gè)就是結(jié)束值了。

如果字段值滿足指定的范圍查詢條件,就返回這些滿足條件的數(shù)據(jù)內(nèi)容。

語(yǔ)法規(guī)則為:

SELECT 字段名 FROM 表名 WHERE 字段名 BETWEEN n1 AND n2; ???????

舉個(gè)例子假設(shè)我們現(xiàn)在有一張表Mall_products,

內(nèi)容如下:

我們將使用BETWEEN AND關(guān)鍵字檢索出所有國(guó)家代碼為1~50的商品的信息。

查詢代碼如下:

SELECT *
FROM Mall_products
WHERE prod_country BETWEEN 1 AND 50;

結(jié)果為:

查詢過程如下:

可以看到,返回結(jié)果包含了國(guó)家代碼從1~50之間的字段值。尤其值得注意的是,端點(diǎn)值1也包含在返回結(jié)果中。

帶NOT BETWEEN AND關(guān)鍵字的查詢

像上一關(guān)介紹的關(guān)鍵字IN一樣,我們還可以對(duì)關(guān)鍵字BETWEEN AND進(jìn)行取反,表示查詢指定范圍之外的值。

語(yǔ)法規(guī)則為:

SELECT 字段名 FROM 表名 WHERE 字段名 NOT BETWEEN n1 AND n2; ???????

舉個(gè)例子我們依然使用表Mall_products。

現(xiàn)在我們想要查詢除了國(guó)家代碼為1~50的所有國(guó)家的產(chǎn)品內(nèi)容。

查詢代碼如下:

SELECT *
FROM Mall_products
WHERE prod_country NOT BETWEEN 1 AND 50;

結(jié)果為:

由結(jié)果可以看出,返回的結(jié)果只有大于國(guó)家代碼50的內(nèi)容。

怎么樣?簡(jiǎn)單吧!

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論