mysql判斷當前時間是否在開始與結(jié)束時間之間且開始與結(jié)束時間允許為空
需求:查詢進行中的活動數(shù)據(jù)
進行中一共有以下幾種情況:
1.開始時間為空,結(jié)束時間為空, 此結(jié)果數(shù)據(jù)將永遠為進行中的數(shù)據(jù)
2.開始時間為空,結(jié)束時間不為空,則當前時間在結(jié)束時間之前,為進行中的數(shù)據(jù)
3.開始時間不為空,結(jié)束時間為空,則當前時間在開始時間之后,為進行中的數(shù)據(jù)
4.開始時間不為空,結(jié)束時間不為空,則當前時間在開始與結(jié)束時間段之內(nèi)的數(shù)據(jù)為進行中數(shù)據(jù)
下面sql則查詢的是滿足以上四種需求的結(jié)果集,達標題需求
SELECT * FROM 表名 WHERE 1=1 and(start_time is null or start_time<now()) and(end_time is null or end_time>now())
mybatis寫法,開始時間與結(jié)束時間傳入?yún)?shù)允許為空
如圖所示:

<if test="record.startDate != null and record.startDate != '' or record.endDate != null and record.endDate != '' ">
AND id in
(select id from rht_product_price where 1=1
<if test="record.startDate != null and record.startDate != ''">
and start_date <= #{record.startDate,jdbcType=VARCHAR}
</if>
<if test="record.endDate!= null and record.endDate != ''">
and end_date >= #{record.endDate,jdbcType=VARCHAR}
</if>
)
</if>
到此這篇關(guān)于mysql判斷當前時間是否在開始與結(jié)束時間之間且開始與結(jié)束時間允許為空的文章就介紹到這了,更多相關(guān)mysql判斷當前時間是否在開始與結(jié)束時間之間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Windows MySQL修改配置文件my.ini不生效問題
在Windows Server 2019上修改MySQL 5.6的安裝目錄下my.ini文件后,需要通過修改注冊表中的ImagePath值來確保MySQL讀取新的配置文件,修改時應(yīng)確保配置文件路徑正確,并且新配置不會覆蓋原有配置,以保證修改生效2025-01-01
MySQL的存儲函數(shù)與存儲過程相關(guān)概念與具體實例詳解
MySQL存儲函數(shù)(自定義函數(shù)),函數(shù)一般用于計算和返回一個值,可以將經(jīng)常需要使用的計算或功能寫成一個函數(shù),存儲函數(shù)和存儲過程一樣,都是在數(shù)據(jù)庫中定義一些SQL語句的集合2023-03-03
php開啟mysqli擴展之后如何連接數(shù)據(jù)庫
Mysqli是php5之后才有的功能,沒有開啟擴展的朋友可以打開您的php.ini的配置文件;相對于mysql有很多新的特性和優(yōu)勢,需要了解的朋友可以參考下2012-12-12

