51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2480|回复: 5
打印 上一主题 下一主题

[求助] 关于MySQL函数的日期天数计算

[复制链接]
  • TA的每日心情
    无聊
    2017-11-26 18:46
  • 签到天数: 382 天

    连续签到: 1 天

    [LV.9]测试副司令

    跳转到指定楼层
    1#
    发表于 2017-9-12 16:40:51 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
    各位坛友:

    我在测试过程中发现开发人员写的SQL中where条件有点问题,希望一起来谈论一下。
    需求是这样的,要刷选出每周,也就是从每周一00:00:01到周日23:59:59这段时间,也就是刚好是7天前整的数据,每周一会。

    开发给的刷选条件是:where CTIME  BETWEEN DATE_SUB(CURDATE(), INTERVAL 7 DAY) and DATE_SUB(CURDATE(), INTERVAL 1 DAY);   


    而我认为的刷选条件是 :where CTIME  BETWEEN DATE_SUB(CURDATE(), INTERVAL 8 DAY) and DATE_SUB(CURDATE(), INTERVAL 1 DAY);   




    ------


    不同之处就是 INTERVAL 7 DAY 和  INTERVAL 8 DAY,我认为若刚好要计算7天整的话,应该是8-1,而不应该是7-1.


    为了说服开发或自已,请各位有MySQL对这个函数有研究的说一下为什么吧……谢谢!

    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    开心
    2020-1-7 10:41
  • 签到天数: 539 天

    连续签到: 1 天

    [LV.9]测试副司令

    6#
    发表于 2017-9-14 10:15:06 | 只看该作者
    神仙也考试 发表于 2017-9-13 10:13
    其实,我要的是完整是 7 * 24  。。。所以才需要确认到底是要7还是8来计算才是最正确的

    哦哦,今天才看到2楼的说法,他回复的应该是你需要的。我之前没接触过date_sub()函数,就是对你发的话题感兴趣,参与讨论,顺便学习下。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2020-1-7 10:41
  • 签到天数: 539 天

    连续签到: 1 天

    [LV.9]测试副司令

    5#
    发表于 2017-9-14 10:09:09 | 只看该作者
    puchonghui 发表于 2017-9-13 08:51
    这个问题的关键在于“每周”的具体界定是什么样的

    按照目前的实现方式,between dataA and dataB会取到d ...

    你好,我追问一下啊,如果楼主说的字段CTIME 在数据表中存储形式是'2017-09-14 0:00:00'(所有数据的时分秒都是0)或'2017-09-14',开发写的就对了,是吗?如果存储的是'2017-09-14 1:01:01'(都有具体时分秒的),那是楼主对了,是不?
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    无聊
    2017-11-26 18:46
  • 签到天数: 382 天

    连续签到: 1 天

    [LV.9]测试副司令

    4#
     楼主| 发表于 2017-9-13 10:13:46 | 只看该作者
    Fighting-ing 发表于 2017-9-13 09:56
    DATE_SUB(date,INTERVAL expr type)
    date 参数是合法的日期表达式。expr 参数是您希望添加的时间间隔。
    ...

    其实,我要的是完整是 7 * 24  。。。所以才需要确认到底是要7还是8来计算才是最正确的
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2020-1-7 10:41
  • 签到天数: 539 天

    连续签到: 1 天

    [LV.9]测试副司令

    3#
    发表于 2017-9-13 09:56:25 | 只看该作者
    DATE_SUB(date,INTERVAL expr type)
    date 参数是合法的日期表达式。expr 参数是您希望添加的时间间隔。
    你用这个验一下就知道了,今天执行下面这2个,
    select SUBDATE(CURDATE(),INTERVAL 7 DAY) 得到的结果是2017-09-06
    select SUBDATE(CURDATE(),INTERVAL 1 DAY) 得到的结果是2017-09-12
    你发的where条件where CTIME  BETWEEN DATE_SUB(CURDATE(), INTERVAL 7 DAY) and DATE_SUB(CURDATE(), INTERVAL 1 DAY);
    不就是 CTIME between 2017-09-06 and 2017-09-12 ,7天么
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2020-8-11 08:18
  • 签到天数: 114 天

    连续签到: 1 天

    [LV.6]测试旅长

    2#
    发表于 2017-9-13 08:51:44 | 只看该作者
    这个问题的关键在于“每周”的具体界定是什么样的

    按照目前的实现方式,between dataA and dataB会取到dataA 0:00:00----dataB 0:00:00

    所以按开发的写法确实会少取24小时的数据
    按你的写法取的时间长度是24*7,但是还要看日期范围是否符合需求

    评分

    参与人数 1测试积点 +10 收起 理由
    lsekfe + 10 奖励原因:乐于助人

    查看全部评分

    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-11 04:12 , Processed in 0.070918 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表