mysql中between的邊界,范圍說(shuō)明
mysql between的邊界范圍
between 的范圍是包含兩邊的邊界值
eg: id between 3 and 7 等價(jià)與 id >=3 and id<=7
not between 的范圍是不包含邊界值
eg:id not between 3 and 7 等價(jià)與 id < 3 or id>7
SELECT * FROM `test` where id BETWEEN 3 and 7; 等價(jià)于 SELECT * FROM `test` where id>=3 and id<=7; ----------------------------------------------------------- SELECT * FROM `test` where id NOT BETWEEN 3 and 7; 等價(jià)于 SELECT * FROM `test` where id<3 or id>7;
mysql between日期邊界的問(wèn)題留意
邊界問(wèn)題:
mysql, between 開(kāi)始日期 AND 結(jié)束日期 包含開(kāi)始日期,不包含結(jié)束日期
例如:
BETWEEN '2018-01-22' AND '2018-01-30'
開(kāi)始日期從2018-01-22 00:00:00.0 開(kāi)始, 到2018-01-29 23:59:59.59結(jié)束
表中的CREATE_DATE 是varchar(21) DEFAULT NULL COMMENT '時(shí)間',
CREATE_DATE中保存值是: 年-月-日 時(shí):分:秒:0 例如: 2018-01-29 23:45:35.0
SELECT * FROM Test a WHERE a.CREATE_DATE BETWEEN '2018-01-22' AND '2018-01-30' ORDER BY a.CREATE_DATE desc
SELECT * FROM TABEL a WHERE a.CREATE_DATE BETWEEN '2018-01-22' AND '2018-01-30' ORDER BY a.CREATE_DATE desc 2018-01-29 23:45:35.0 20180129 2018-01-29 23:45:33.0 20180129 2018-01-29 00:10:58.0 20180129 2018-01-29 00:10:45.0 20180129 2018-01-28 23:42:23.0 20180128 2018-01-28 23:39:39.0 20180128 SELECT * FROM TABEL a WHERE a.CREATE_DATE BETWEEN '2018-01-22' AND '2018-01-29' ORDER BY a.CREATE_DATE desc 2018-01-28 23:42:23.0 20180128 2018-01-28 23:39:39.0 20180128 2018-01-28 00:13:22.0 20180128 2018-01-28 00:13:19.0 20180128 2018-01-27 23:23:02.0 20180127 2018-01-22 00:09:59.0 20180122 2018-01-22 00:09:56.0 20180122 2018-01-22 00:01:53.0 20180122
遇到的其他問(wèn)題:
遇到另外一張表 test2 有保存時(shí)間的字段: `REPORTTIME` varchar(45) DEFAULT NULL,
這個(gè)字段保存的值是:
例子1:
select * from bips_hpd_helpdesk a WHERE str_to_date(from_unixtime(a.REPORTTIME,'%Y-%m-%d'),'%Y-%m-%d') BETWEEN '2018-01-16' AND '2018-01-27' ORDER BY from_unixtime(a.REPORTTIME,'%Y-%m-%d') DESC ;
結(jié)果1:
從結(jié)果中,可以看到取到了27號(hào)的數(shù)據(jù),可能是處理的時(shí)間沒(méi)有 小時(shí),分鐘,秒。
例子2:
select * from bips_hpd_helpdesk a WHERE str_to_date(from_unixtime(a.REPORTTIME,'%Y-%m-%d'),'%Y-%m-%d') BETWEEN str_to_date('2018-01-16','%Y-%m-%d') AND str_to_date('2018-01-27','%Y-%m-%d')
結(jié)果2:
找到問(wèn)題: 毫秒值轉(zhuǎn)換為時(shí)間,發(fā)現(xiàn)這里保存的毫秒值,沒(méi)有保存時(shí)分秒:
from_unixtime(a.REPORTTIME,'%Y-%m-%d') AS reportTime,a.REPORTTIME, str_to_date(from_unixtime(a.REPORTTIME,'%Y-%m-%d'),'%Y-%m-%d %h:%i:%s') AS reportTime22 FROM test a WHERE str_to_date(from_unixtime(a.REPORTTIME,'%Y-%m-%d'),'%Y-%m-%d %h:%i:%s') BETWEEN str_to_date('2018-01-16','%Y-%m-%d %h:%i:%s') AND str_to_date('2018-01-27 %h:%i:%s','%Y-%m-%d') #subdate(curdate(),date_format(curdate(),'%w')-1) AND subdate(curdate(),date_format(curdate(),'%w')-8) ORDER BY from_unixtime(a.REPORTTIME,'%Y-%m-%d') DESC ;
查看到的時(shí)間值:
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Mac OS系統(tǒng)下mysql 5.7.20安裝教程圖文詳解
這篇文章主要介紹了Mac OS系統(tǒng)下mysql 5.7.20安裝教程圖文詳解,本文給大家介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-11-11MySQL常用命令 MySQL處理數(shù)據(jù)庫(kù)和表的命令
這篇文章主要介紹了MySQL常用命令,尤其是針對(duì)MySQL處理數(shù)據(jù)庫(kù)和表的命令進(jìn)行學(xué)習(xí),特別適用于新手,感興趣的小伙伴們可以參考一下2015-11-11SQL使用ROW_NUMBER() OVER函數(shù)生成序列號(hào)
這篇文章主要介紹了SQL使用ROW_NUMBER() OVER函數(shù)生成序列號(hào),ROW_NUMBER()從1開(kāi)始,為每一條分組記錄返回一個(gè)數(shù)字,下面文章內(nèi)容具有一定的參考價(jià)值,需要的小伙伴可以參考一下2021-12-12詳解MySQL實(shí)現(xiàn)主從復(fù)制過(guò)程
這篇文章主要為大家詳細(xì)介紹了MySQL主從復(fù)制的實(shí)現(xiàn)過(guò)程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07InnoDB的關(guān)鍵特性-插入緩存,兩次寫(xiě),自適應(yīng)hash索引詳解
下面小編就為大家?guī)?lái)一篇InnoDB的關(guān)鍵特性-插入緩存,兩次寫(xiě),自適應(yīng)hash索引詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03服務(wù)器不支持 MySql 數(shù)據(jù)庫(kù)的解決方法
出現(xiàn)問(wèn)題:報(bào)錯(cuò)“服務(wù)器不支持 MySql 數(shù)據(jù)庫(kù)”,改函數(shù)function_exists('mysql_connect')返回 false2013-03-03Centos 7 安裝mysql5.7.24二進(jìn)制 版本的方法及解決辦法
這篇文章主要介紹了Centos 7 安裝mysql5.7.24二進(jìn)制 版本的方法 及遇到問(wèn)題解決辦法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-11-11