溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現(xiàn)在一個時間段內(nèi)進行間隔查詢

發(fā)布時間:2021-09-24 11:51:45 來源:億速云 閱讀:307 作者:iii 欄目:數(shù)據(jù)庫

這篇文章主要介紹“如何實現(xiàn)在一個時間段內(nèi)進行間隔查詢”,在日常操作中,相信很多人在如何實現(xiàn)在一個時間段內(nèi)進行間隔查詢問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何實現(xiàn)在一個時間段內(nèi)進行間隔查詢”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

我想在一個時間段內(nèi)然后按照間隔時間來查詢數(shù)據(jù)
select * from 監(jiān)控溫度表 where 監(jiān)控溫度表.時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "'order by id
這個是在一個時間段內(nèi)查詢,現(xiàn)在要加個時間間隔來查詢,不知所云,望高手解答
其中dtStart.Value和dtEnd.Value是DTPicker1控件
舉例:比如說我查詢時間段在 2007-1-5 19:03:31到2007-4-8 10:38:21以為在這之間沒隔幾秒就有一個數(shù)據(jù)現(xiàn)在不想讓他全取出來,我要個5分鐘或者多少時間取一個數(shù)據(jù)。如現(xiàn)在我2007-1-5 19:03:31有個記錄,下個記錄就直接是2007-1-5 19:08:31這個記錄(如沒這么記錄就在這個記錄的前后最接近取個記錄),而在2007-1-5 19:03:31置2007-1-5 19:08:31很多數(shù)據(jù)就不顯示出來了,謝謝各位啊

try

select * from 監(jiān)控溫度表 A where 時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "' And Not Exists (Select 時間 From 監(jiān)控溫度表 Where DateDiff(mi, 時間, A.時間) <=5 ) order by id

我想那個間隔時間是可以改的
比如加個text
text1.text=間隔時間
先謝謝樓上的

將text1.text加進去,試下這個,

select * from 監(jiān)控溫度表 A where 時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "' And Not Exists (Select 時間 From 監(jiān)控溫度表 Where DateDiff(mi, 時間, A.時間) <= " + Str(text1.text) + ") order by id

A是表的別名

“text1.text=間隔時間”,你的text1.text中輸入的內(nèi)容是什麼,使用那條語句的時候,text1.text中只能輸入間隔的分鐘數(shù),比如5。

也可以,如果你的固定是分鐘間隔的話


就是這麼寫
Select * From 監(jiān)控溫度表 Where 監(jiān)控溫度表.時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "'  And DateDiff(mi,'" + Str(dtStart.Value) + "',時間) % " + Str(text1.text) + "=0  Order By id

把做的原理搞清楚就比較容易實現(xiàn)了:

1.合成一個計算列,這個計算列就是將"監(jiān)控溫度表.時間"與一個基準時間做一個Datediff,計算它們之間的差距,比如說按分鐘取差距.
2.使用第一步的結果集做為表,再在這外部放置一個SQL用于做篩選,比如說每隔5分鐘取一次的話就這么用:where 計算列 % 5 = 0

這樣想好了就會非常容易實現(xiàn)了

按我上面所說的思路來實踐一下:
    具體實現(xiàn)時也可以直接在Where里面直接將第一步做完,可以這么做:

    "Select * From 監(jiān)控溫度表 Where 監(jiān)控溫度表.時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "'  And DateDiff(" + "mi" + ",'" + Str(dtStart.Value) + "',時間) % " + "5" + "=0  Order By id"

    注意這上面我在條件中多加入了時間間隔的判斷, 注意DateDiff函數(shù)的第1個參數(shù),我用的是mi(兩邊不能帶單引號),這代表的是按分鐘求間隔,還有后的 5 ,代表的是間隔5個單位(模5=0),合起來就成為了從開始時間算起,每隔5分鐘

到此,關于“如何實現(xiàn)在一個時間段內(nèi)進行間隔查詢”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

sql
AI