主页 > 知识库 > 问个高难度的复杂查询(在一个时间段内的间隔查询)

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

热门标签:百度竞价排名 AI电销 铁路电话系统 网站排名优化 地方门户网站 呼叫中心市场需求 服务外包 Linux服务器
我想在一个时间段内然后按照间隔时间来查询数据
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分钟

您可能感兴趣的文章:
  • PHP syntax error, unexpected $end 错误的一种原因及解决
  • jQuery选中select控件 无法设置selected的解决方法
  • php iconv() : Detected an illegal character in input string
  • php异常:Parse error: syntax error, unexpected T_ENCAPSED_AND_WHITESPACE eval()''d code error
  • PHP Parse Error: syntax error, unexpected $end 错误的解决办法
  • w3wp进程发生死锁ISAPI aspnet_isapi.dll报告它自身有问题,原因Deadlock detected
  • jquery.bgiframe.js在IE9下提示INVALID_CHARACTER_ERR错误
  • C++中的三种继承public,protected,private详细解析
  • CodeIgniter框架提示Disallowed Key Characters的解决办法
  • PHP异常Parse error: syntax error, unexpected T_VAR错误解决方法
  • pycharm 使用心得(九)解决No Python interpreter selected的问题
  • PHP错误Parse error: syntax error, unexpected end of file in test.php on line 12解决方法
  • 强制SQL Server执行计划使用并行提升在复杂查询语句下的性能
  • 深入理解C++中public、protected及private用法
  • jQuery中:selected选择器用法实例
  • 在sqlserver中如何使用CTE解决复杂查询问题
 

标签:兰州 湖南 崇左 湘潭 铜川 仙桃 衡水 黄山

巨人网络通讯声明:本文标题《问个高难度的复杂查询(在一个时间段内的间隔查询)》,本文关键词  问个,高难度,的,复杂,查询,在,一个,时间段,内,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266