mysql之查詢兩個(gè)時(shí)間段是否有交集的情況
mysql查詢兩個(gè)時(shí)間段是否有交集的情況
數(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時(shí)間段交集查詢
可訂房間的查詢邏輯(時(shí)間段沒有相交的時(shí)間段),這個(gè)sql可以直接扔到navicat運(yùn)行校驗(yàn)下
相交分為以下四種情況情況
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)開始時(shí)間', `end_time` datetime DEFAULT NULL COMMENT '房態(tài)結(jié)束時(shí)間', 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(shí)間 set @s = '2020-05-18 23:59:59'; -- 查詢離店時(shí)間 set @e = '2020-05-21 00:00:00'; -- 這個(gè)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); -- 這個(gè)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é)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
mysql 發(fā)生系統(tǒng)錯(cuò)誤1067的解決方法
今天要把WEB項(xiàng)目打包成EXE,可是在數(shù)據(jù)庫上卡住了。在啟動(dòng)數(shù)據(jù)庫服務(wù)的時(shí)候發(fā)生系統(tǒng)錯(cuò)誤 1067。2009-09-09使用SQL實(shí)現(xiàn)按每小時(shí)統(tǒng)計(jì)數(shù)據(jù)
在數(shù)據(jù)分析和報(bào)表生成中,按小時(shí)統(tǒng)計(jì)數(shù)據(jù)是一個(gè)常見的需求,因?yàn)樾r(shí)級(jí)別的數(shù)據(jù)統(tǒng)計(jì)都能提供細(xì)致且有價(jià)值的信息,下面我們就來看看具體實(shí)現(xiàn)方法吧2024-11-11MySQL配置了雙主,是如何避免出現(xiàn)數(shù)據(jù)回環(huán)沖突的
這篇文章主要介紹了MySQL配置了雙主,是如何避免出現(xiàn)數(shù)據(jù)回環(huán)沖突的,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下2021-01-01Windows平臺(tái)配置5.7版本+MySQL數(shù)據(jù)庫服務(wù)
這篇文章主要介紹了Windows平臺(tái)配置5.7版本+MySQL數(shù)據(jù)庫服務(wù)的方法,包括初始化root用戶密碼password的過程以及兩個(gè)常見問題的解決方法,需要的朋友參考下吧2017-06-06MYSQL復(fù)雜查詢練習(xí)題以及答案大全(難度適中)
在我們學(xué)習(xí)mysql數(shù)據(jù)庫時(shí)需要一些題目進(jìn)行練習(xí),下面這篇文章主要給大家介紹了關(guān)于MYSQL復(fù)雜查詢練習(xí)題以及答案的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),這些練習(xí)題難度適中,需要的朋友可以參考下2022-08-08CentOS 7.2下MySQL的安裝與相關(guān)配置
最近因?yàn)楣ぷ餍枰贑entOS上安裝MySQL,在安裝的時(shí)候遇到了一點(diǎn)問題,花了點(diǎn)時(shí)間解決了,感覺不管是官網(wǎng)還是網(wǎng)上的一些教程都不夠完整,不能一次性幫新手解決問題,于是我就結(jié)合官網(wǎng)和網(wǎng)上的資源整理了下,現(xiàn)在分享給大家,希望對有需要的朋友們能有所幫助。2016-11-11mysql Buffer Pool的存儲(chǔ)結(jié)構(gòu)和內(nèi)存淘汰機(jī)制詳解
這篇文章主要介紹了mysql Buffer Pool的存儲(chǔ)結(jié)構(gòu)和內(nèi)存淘汰機(jī)制詳解,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03MySQL 5.7雙主同步部分表的實(shí)現(xiàn)過程詳解
這篇文章主要給大家介紹了關(guān)于MySQL 5.7雙主同步部分表實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09