mysql之查詢兩個時間段是否有交集的情況
mysql查詢兩個時間段是否有交集的情況
數(shù)據(jù)庫的字段 start_time, end_time
輸入的字段 a,b
第一種
SELECT * FROM test_table WHERE ? ? (start_time >= a AND start_time <= b) ? ? OR (start_time <= a AND end_time >= b) ? ? OR (end_time >= a AND end_time <= b)?
第二種
SELECT * FROM test_table WHERE ? ? NOT ( ? ? ? ? (end_time < a ? ? ? ? OR (start_time > b) ? ? )?
兩種結(jié)果相同
mysql時間段交集查詢
可訂房間的查詢邏輯(時間段沒有相交的時間段),這個sql可以直接扔到navicat運行校驗下
相交分為以下四種情況情況
drop table if EXISTS `test_date`; CREATE TABLE `test_date` ( `id` int(11) NOT NULL AUTO_INCREMENT, `room_id` int(11) DEFAULT NULL COMMENT '房間id', `start_time` datetime DEFAULT NULL COMMENT '房態(tài)開始時間', `end_time` datetime DEFAULT NULL COMMENT '房態(tài)結(jié)束時間', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci; INSERT INTO `test`.`test_date`(`id`, `room_id`, `start_time`, `end_time`) VALUES (1, 1, '2020-05-20 15:00:00', '2020-05-22 12:00:00'); INSERT INTO `test`.`test_date`(`id`, `room_id`, `start_time`, `end_time`) VALUES (2, 1, '2020-05-25 15:00:00', '2020-05-27 12:00:00'); -- 查詢?nèi)胱r間 set @s = '2020-05-18 23:59:59'; -- 查詢離店時間 set @e = '2020-05-21 00:00:00'; -- 這個sql查詢出來的話,是不合適的數(shù)據(jù),有重疊 select * from test_date where (start_time <= @s and end_time >= @s) or (start_time <= @e and end_time >= @e) or (start_time >= @s and end_time <= @e) or (start_time <= @s and end_time >= @e); -- 這個sql不加反,求出來的是合適的數(shù)據(jù),不重疊的數(shù)據(jù) -- 取反,就是重疊的數(shù)據(jù),日期不符合規(guī)范的數(shù)據(jù),有相交的數(shù)據(jù) select * from test_date where !(start_time >= @e or end_time <= @s);
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
mysql 發(fā)生系統(tǒng)錯誤1067的解決方法
今天要把WEB項目打包成EXE,可是在數(shù)據(jù)庫上卡住了。在啟動數(shù)據(jù)庫服務(wù)的時候發(fā)生系統(tǒng)錯誤 1067。2009-09-09使用SQL實現(xiàn)按每小時統(tǒng)計數(shù)據(jù)
在數(shù)據(jù)分析和報表生成中,按小時統(tǒng)計數(shù)據(jù)是一個常見的需求,因為小時級別的數(shù)據(jù)統(tǒng)計都能提供細致且有價值的信息,下面我們就來看看具體實現(xiàn)方法吧2024-11-11MySQL配置了雙主,是如何避免出現(xiàn)數(shù)據(jù)回環(huán)沖突的
這篇文章主要介紹了MySQL配置了雙主,是如何避免出現(xiàn)數(shù)據(jù)回環(huán)沖突的,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下2021-01-01Windows平臺配置5.7版本+MySQL數(shù)據(jù)庫服務(wù)
這篇文章主要介紹了Windows平臺配置5.7版本+MySQL數(shù)據(jù)庫服務(wù)的方法,包括初始化root用戶密碼password的過程以及兩個常見問題的解決方法,需要的朋友參考下吧2017-06-06MYSQL復(fù)雜查詢練習(xí)題以及答案大全(難度適中)
在我們學(xué)習(xí)mysql數(shù)據(jù)庫時需要一些題目進行練習(xí),下面這篇文章主要給大家介紹了關(guān)于MYSQL復(fù)雜查詢練習(xí)題以及答案的相關(guān)資料,文中通過實例代碼介紹的非常詳細,這些練習(xí)題難度適中,需要的朋友可以參考下2022-08-08CentOS 7.2下MySQL的安裝與相關(guān)配置
最近因為工作需要,要在CentOS上安裝MySQL,在安裝的時候遇到了一點問題,花了點時間解決了,感覺不管是官網(wǎng)還是網(wǎng)上的一些教程都不夠完整,不能一次性幫新手解決問題,于是我就結(jié)合官網(wǎng)和網(wǎng)上的資源整理了下,現(xiàn)在分享給大家,希望對有需要的朋友們能有所幫助。2016-11-11mysql Buffer Pool的存儲結(jié)構(gòu)和內(nèi)存淘汰機制詳解
這篇文章主要介紹了mysql Buffer Pool的存儲結(jié)構(gòu)和內(nèi)存淘汰機制詳解,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-03-03