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

 更新时间:2007年04月23日 00:00:00   作者:  
我想在一个时间段内然后按照间隔时间来查询数据
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分钟

相关文章

  • Navicat添加外键详细操作步骤

    Navicat添加外键详细操作步骤

    这篇文章主要介绍了Navicat添加外键详细操作步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Hadoop2.X/YARN环境搭建--CentOS7.0系统配置

    Hadoop2.X/YARN环境搭建--CentOS7.0系统配置

    Hadoop原本来自于谷歌一款名为MapReduce的编程模型包。谷歌的MapReduce框架可以把一个应用程序分解为许多并行计算指令,跨大量的计算节点运行非常巨大的数据集。使用该框架的一个典型例子就是在网络数据上运行的搜索算法。
    2014-08-08
  • Dbeaver做数据迁移的详细过程记录

    Dbeaver做数据迁移的详细过程记录

    DBeaver是一款跨平台的通用数据库开源管理工具,支持 MySQL,PostgreSQL,Oracle,DB2,MSSQL,Sybase,Mimer,HSQLDB,Derby以及其他兼容JDBC的数据库,下面这篇文章主要给大家介绍了关于Dbeaver做数据迁移的详细过程,需要的朋友可以参考下
    2023-05-05
  • 在SQL Server和Oracle中创建job

    在SQL Server和Oracle中创建job

    有的时候,我们可能需要在数据库中设定一些自动执行的任务(job),以此来自动完成一些包括统计、备份方面的需求,下面就简单说明一下有关ms server和oracle两种数据库中如何新建自动任务。
    2009-06-06
  • where 子句的执行顺序

    where 子句的执行顺序

    貌似在2005之前的版本中,where子句的顺序是从前往后的。但是又貌似在2005的版本中进行了优化,所有的顺序都被统一成了以过滤能力进行排序的语句。
    2009-04-04
  • DataGrip 连接 HiveServer2 报错的问题

    DataGrip 连接 HiveServer2 报错的问题

    这篇文章主要介绍了DataGrip 连接 HiveServer2 报错的问题,本文通过图文实例相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • 数据库之SQL注入原理以及过程的简单介绍

    数据库之SQL注入原理以及过程的简单介绍

    这篇文章主要介绍了数据库之SQL注入原理以及过程的简单介绍,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • 一文详解SQL中为什么不要使用1=1

    一文详解SQL中为什么不要使用1=1

    很多时候使用where 1=1 可以很方便的解决我们的问题,但是这样很可能会造成非常大的性能损失,这篇文章主要给大家介绍了关于SQL中为什么不要使用1=1的相关资料,需要的朋友可以参考下
    2024-03-03
  • 深入SQL中PIVOT 行列转换详解

    深入SQL中PIVOT 行列转换详解

    T-SQL语句中,Pivot运算符用于在列和行之间对数据进行旋转或透视转换,PIVOT命令可以实现数据表的列转行,同时执行聚合运算,UNPIVOT则与其相反,实现数据的行转列。
    2015-10-10
  • Linux下Navicat15激活的详细步骤

    Linux下Navicat15激活的详细步骤

    这篇文章主要介绍了Linux下激活Navicat15的详细步骤,经过测试Navicat 15.0.8版本可激活,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08

最新评论