濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > mysql中between的邊界,范圍說明

mysql中between的邊界,范圍說明

熱門標(biāo)簽:南太平洋地圖標(biāo)注 400電話辦理服務(wù)價(jià)格最實(shí)惠 400電話變更申請(qǐng) 大豐地圖標(biāo)注app 催天下外呼系統(tǒng) html地圖標(biāo)注并導(dǎo)航 武漢電銷機(jī)器人電話 北京金倫外呼系統(tǒng) 呂梁外呼系統(tǒng)

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 id3 or id>7;

mysql between日期邊界的問題留意

邊界問題:

mysql, between 開始日期 AND 結(jié)束日期 包含開始日期,不包含結(jié)束日期

例如:

BETWEEN '2018-01-22' AND  '2018-01-30'

開始日期從2018-01-22 00:00:00.0 開始, 到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

遇到的其他問題:

遇到另外一張表 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í)間沒有 小時(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:

找到問題: 毫秒值轉(zhuǎn)換為時(shí)間,發(fā)現(xiàn)這里保存的毫秒值,沒有保存時(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è)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • MySQL中BETWEEN子句的用法詳解
  • MySQL的WHERE語句中BETWEEN與IN的使用教程
  • 詳解Mysql中日期比較大小的方法

標(biāo)簽:無錫 西寧 麗水 南充 徐州 迪慶 自貢 龍巖

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mysql中between的邊界,范圍說明》,本文關(guān)鍵詞  mysql,中,between,的,邊界,范圍,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mysql中between的邊界,范圍說明》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于mysql中between的邊界,范圍說明的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    天全县| 如皋市| 山西省| 梓潼县| 都匀市| 郸城县| 新野县| 上栗县| 蓬安县| 瑞金市| 汾阳市| 修文县| 松溪县| 台东市| 襄樊市| 文水县| 洪江市| 紫云| 新密市| 宁远县| 大关县| 云和县| 齐齐哈尔市| 闸北区| 鹿邑县| 揭东县| 株洲市| 通城县| 枝江市| 昌乐县| 鄂托克前旗| 五河县| 香港 | 遂平县| 左贡县| 五指山市| 太和县| 班戈县| 黄骅市| 肥东县| 岳阳市|