mysql判斷當(dāng)前時(shí)間是否在開始與結(jié)束時(shí)間之間且開始與結(jié)束時(shí)間允許為空
需求:查詢進(jìn)行中的活動(dòng)數(shù)據(jù)
進(jìn)行中一共有以下幾種情況:
1.開始時(shí)間為空,結(jié)束時(shí)間為空, 此結(jié)果數(shù)據(jù)將永遠(yuǎn)為進(jìn)行中的數(shù)據(jù)
2.開始時(shí)間為空,結(jié)束時(shí)間不為空,則當(dāng)前時(shí)間在結(jié)束時(shí)間之前,為進(jìn)行中的數(shù)據(jù)
3.開始時(shí)間不為空,結(jié)束時(shí)間為空,則當(dāng)前時(shí)間在開始時(shí)間之后,為進(jìn)行中的數(shù)據(jù)
4.開始時(shí)間不為空,結(jié)束時(shí)間不為空,則當(dāng)前時(shí)間在開始與結(jié)束時(shí)間段之內(nèi)的數(shù)據(jù)為進(jìn)行中數(shù)據(jù)
下面sql則查詢的是滿足以上四種需求的結(jié)果集,達(dá)標(biāo)題需求
SELECT * FROM 表名 WHERE 1=1 and(start_time is null or start_time<now()) and(end_time is null or end_time>now())
mybatis寫法,開始時(shí)間與結(jié)束時(shí)間傳入?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判斷當(dāng)前時(shí)間是否在開始與結(jié)束時(shí)間之間且開始與結(jié)束時(shí)間允許為空的文章就介紹到這了,更多相關(guān)mysql判斷當(dāng)前時(shí)間是否在開始與結(jié)束時(shí)間之間內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL?MyBatis?默認(rèn)插入當(dāng)前時(shí)間方式
- mysql時(shí)間字段默認(rèn)設(shè)置為當(dāng)前時(shí)間實(shí)例代碼
- MySql獲取當(dāng)前時(shí)間并轉(zhuǎn)換成字符串的實(shí)現(xiàn)
- MySQL中查詢當(dāng)前時(shí)間間隔前1天的數(shù)據(jù)
- 解析MySQL設(shè)置當(dāng)前時(shí)間為默認(rèn)值的方法
- mysql中取系統(tǒng)當(dāng)前時(shí)間,當(dāng)前日期方便查詢判定的代碼
- MYSQL設(shè)置字段自動(dòng)獲取當(dāng)前時(shí)間的sql語句
相關(guān)文章
Mysql中使用count加條件統(tǒng)計(jì)的實(shí)現(xiàn)示例
本文主要介紹了Mysql中使用count加條件統(tǒng)計(jì)的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07詳解MySQL實(shí)時(shí)同步到Oracle解決方案
這篇文章主要介紹了詳解MySQL實(shí)時(shí)同步到Oracle解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03Mysql事務(wù)的隔離級(jí)別(臟讀+幻讀+可重復(fù)讀)
這篇文章主要介紹了Mysql事務(wù)的隔離級(jí)別(臟讀+幻讀+可重復(fù)讀),文章通告InnoDB展開詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2022-08-08linux配置mysql數(shù)據(jù)庫遠(yuǎn)程連接失敗的解決方法
這篇文章主要為大家詳細(xì)介紹了linux配置mysql數(shù)據(jù)庫遠(yuǎn)程連接失敗的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06