lilithsir 2020-08-18 10:07 采纳率: 0%
浏览 71
已结题

我想要一小时数据里进行筛选,为什么数据库没执行

 WHERE dt>DateAdd(MINUTE,-1,DateAdd(SECOND,-DATEPART(SECOND,@ct),DateAdd(MINUTE,-DATEPART(MINUTE,@ct),@ct)))
        AND dt<DateAdd(HOUR,1,DateAdd(SECOND,-DATEPART(SECOND,@ct),DateAdd(MINUTE,-DATEPART(MINUTE,@ct),@ct)))
  • 写回答

1条回答 默认 最新

  • jingluan666 2020-08-18 12:27
    关注

    上面的sql应该是sqlserver的tsql,而不是mysql

    如果不清楚条件是否正确,可以像这样测试:

    DECLARE @ct DATETIME;
    SET @ct='2020-06-02 11:52:35';
    SELECT DateAdd(MINUTE,-1,DateAdd(SECOND,-DATEPART(SECOND,@ct),DateAdd(MINUTE,-DATEPART(MINUTE,@ct),@ct)))
    SELECT DateAdd(HOUR,1,DateAdd(SECOND,-DATEPART(SECOND,@ct),DateAdd(MINUTE,-DATEPART(MINUTE,@ct),@ct)))
    

    输出结果

    2020-06-02 10:59:00.000
    2020-06-02 12:00:00.000
    

    你的条件是筛选临近当前时间整点的前一个小时的,但是貌似多了一秒

    评论

报告相同问题?

悬赏问题

  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启