我想在一个时间段内然后按照间隔时间来查询数据
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分钟
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分钟
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
更新日志
2024年05月20日
2024年05月20日
- 雷普利 Ripley
- 燕云十六声卷二烈言所有宝箱位置一览
- 崩坏星穹铁道神秘人交给你的线索位置大全
- 少年西游记2众生轮回活动攻略 2个玩法解析
- 出发吧麦芬古遗迹上的幽影试炼怎么过 古遗迹上的幽影阵容打法攻略
- 出发吧麦芬三宝齐聚黄金船试炼怎么过 三宝齐聚黄金船阵容打法攻略
- 鸣潮渊武适配武器选什么 渊武四星五星武器推荐
- 618优选技嘉B760M冰雕X,纯白海景房装机小钢炮
- 《荒野大镖客:救赎》或将加入XGP和PS Premium
- 荒野之息 vs 王国之泪!IGN评选最佳Switch游戏TOP25
- 痛仰乐队.2017-今日青年【摩登天空】【WAV+CUE】
- 【柔顺爵士】Threestyle-2024-NoMatterWhat(FLAC)
- 马人乐团.2011-鞭风再起【喜玛拉雅】【WAV+CUE】
- 杨奇谈《黑神话:悟空》:感谢老师们几年来胸怀明月 休休有容
- 《黑神话:悟空》金箍首次亮相!疑致敬《大话西游》