香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > 数据库 >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

问个高难度的复杂查询(在一个时间段内的间隔查询)


时间:2020-11-19 14:18 作者:admin


我想在一个时间段内然后按照间隔时间来查询数据
select*from监控温度表where监控温度表.时间between'"+Str(dtStart.Value)+"'AND'"+Str(dtEnd.Value)+"'orderbyid
这个是在一个时间段内查询,现在要加个时间间隔来查询,不知所云,望高手解答
其中dtStart.Value和dtEnd.Value是DTPicker1控件
举例:比如说我查询时间段在2007-1-519:03:31到2007-4-810:38:21以为在这之间没隔几秒就有一个数据现在不想让他全取出来,我要个5分钟或者多少时间取一个数据。如现在我2007-1-519:03:31有个记录,下个记录就直接是2007-1-519:08:31这个记录(如没这么记录就在这个记录的前后最接近取个记录),而在2007-1-519:03:31置2007-1-519:08:31很多数据就不显示出来了,谢谢各位啊

try

select*from监控温度表Awhere时间between'"+Str(dtStart.Value)+"'AND'"+Str(dtEnd.Value)+"'AndNotExists(Select时间From监控温度表WhereDateDiff(mi,时间,A.时间)<=5)orderbyid

我想那个间隔时间是可以改的
比如加个text
text1.text=间隔时间
先谢谢楼上的

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

select*from监控温度表Awhere时间between'"+Str(dtStart.Value)+"'AND'"+Str(dtEnd.Value)+"'AndNotExists(Select时间From监控温度表WhereDateDiff(mi,时间,A.时间)<="+Str(text1.text)+")orderbyid

A是表的別名

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

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


就是這麼寫
Select*From监控温度表Where监控温度表.时间between'"+Str(dtStart.Value)+"'AND'"+Str(dtEnd.Value)+"'AndDateDiff(mi,'"+Str(dtStart.Value)+"',时间)%"+Str(text1.text)+"=0OrderByid

把做的原理搞清楚就比较容易实现了:

1.合成一个计算列,这个计算列就是将"监控温度表.时间"与一个基准时间做一个Datediff,计算它们之间的差距,比如说按分钟取差距.
2.使用第一步的结果集做为表,再在这外部放置一个SQL用于做筛选,比如说每隔5分钟取一次的话就这么用:where计算列%5=0

这样想好了就会非常容易实现了

按我上面所说的思路来实践一下:
具体实现时也可以直接在Where里面直接将第一步做完,可以这么做:

"Select*From监控温度表Where监控温度表.时间between'"+Str(dtStart.Value)+"'AND'"+Str(dtEnd.Value)+"'AndDateDiff("+"mi"+",'"+Str(dtStart.Value)+"',时间)%"+"5"+"=0OrderByid"

注意这上面我在条件中多加入了时间间隔的判断,注意DateDiff函数的第1个参数,我用的是mi(两边不能带单引号),这代表的是按分钟求间隔,还有后的5,代表的是间隔5个单位(模5=0),合起来就成为了从开始时间算起,每隔5分钟

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)