我想在一個時間段內然後按照間隔時間來查詢資料
select * from 監控溫度表 where 監控溫度表.時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "'order by id
這個是在一個時間段內查詢,現在要加個時間間隔來查詢,不知所云,望高手解答
其中dtStart.Value和dtEnd.Value是DTPicker1控制項
舉例:比如說我查詢時間段在 2007-1-5 19:03:31到2007-4-8 10:38:21以為在這之間沒隔幾秒就有一個資料現在不想讓他全取出來,我要個5分鐘或者多少時間取一個資料。如現在我2007-1-5 19:03:31有個記錄,下個記錄就直接是2007-1-5 19:08:31這個記錄(如沒這麼記錄就在這個記錄的前後最接近取個記錄),而在2007-1-5 19:03:31置2007-1-5 19:08:31很多資料就不顯示出來了,謝謝各位啊
try
select * from 監控溫度表 A where 時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "' And Not Exists (Select 時間 From 監控溫度表 Where DateDiff(mi, 時間, A.時間) <=5 ) order by id
我想那個間隔時間是可以改的
比如加個text
text1.text=間隔時間
先謝謝樓上的
將text1.text加進去,試下這個,
select * from 監控溫度表 A where 時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "' And Not Exists (Select 時間 From 監控溫度表 Where DateDiff(mi, 時間, A.時間) <= " + Str(text1.text) + ") order by id
A是表的別名
“text1.text=間隔時間”,你的text1.text中輸入的內容是什麼,使用那條語句的時候,text1.text中只能輸入間隔的分鐘數,比如5。
也可以,如果你的固定是分鐘間隔的話
就是這麼寫
Select * From 監控溫度表 Where 監控溫度表.時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "' And DateDiff(mi,'" + Str(dtStart.Value) + "',時間) % " + Str(text1.text) + "=0 Order By id
把做的原理搞清楚就比較容易實現了:
1.合成一個計算資料行,這個計算資料行就是將"監控溫度表.時間"與一個基準時間做一個Datediff,計算它們之間的差距,比如說按分鐘取差距.
2.使用第一步的結果集做為表,再在這外部放置一個SQL用於做篩選,比如說每隔5分鐘取一次的話就這麼用:where 計算資料行 % 5 = 0
這樣想好了就會非常容易實現了
按我上面所說的思路來實踐一下:
具體實現時也可以直接在Where裡面直接將第一步做完,可以這麼做:
"Select * From 監控溫度表 Where 監控溫度表.時間 between '" + Str(dtStart.Value) + "'AND '" + Str(dtEnd.Value) + "' And DateDiff(" + "mi" + ",'" + Str(dtStart.Value) + "',時間) % " + "5" + "=0 Order By id"
注意這上面我在條件中多加入了時間間隔的判斷, 注意DateDiff函數的第1個參數,我用的是mi(兩邊不能帶單引號),這代表的是按分鐘求間隔,還有後的 5 ,代表的是間隔5個單位(模5=0),合起來就成為了從開始時間算起,每隔5分鐘