mysql 常见的时间查询

本贴最后更新于 2700 天前,其中的信息可能已经时移俗易

最近使用的一些 时间查询统计

测试表结构如下:
Create Table |

CREATE TABLE test_t (
id int(10) NOT NULL AUTO_INCREMENT,
create_time datetime DEFAULT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8

两个字段 方便操作
测试数据如下:

ac3917ef3ff24044a89197002e675548-image.png

insert into test_t (id, create_time) values('1','2017-11-03 14:22:50');
insert into test_t (id, create_time) values('2','2017-11-04 14:22:54');
insert into test_t (id, create_time) values('3','2017-11-03 14:22:57');
insert into test_t (id, create_time) values('4','2017-11-01 14:23:00');
insert into test_t (id, create_time) values('5','2017-11-05 14:23:03');
insert into test_t (id, create_time) values('6','2017-11-01 14:23:11');
insert into test_t (id, create_time) values('7','2017-11-07 14:23:15');
insert into test_t (id, create_time) values('8','2017-11-02 14:23:27');
insert into test_t (id, create_time) values('9','2017-10-31 14:23:40');
insert into test_t (id, create_time) values('10','2017-11-06 14:38:37');
insert into test_t (id, create_time) values('11','2017-07-21 15:38:25');
insert into test_t (id, create_time) values('12','2017-08-18 15:38:35');
insert into test_t (id, create_time) values('13','2017-11-07 15:53:48');
insert into test_t (id, create_time) values('14','2016-11-07 16:20:25');

为了方便查看 , 都叫上了 order by 排序

1.要统计每日的新增数据 ,就要把时间戳格式的时间 FORMAT 成年-月-日的格式,并按照 format 过的字段做分组(group by),计算 count

  • SELECT DATE_FORMAT(create_time,'%Y-%m-%d') AS TIME , COUNT(*) AS COUNT FROM test_t GROUP BY TIME
    92f626f294d0438d860b2b3bb8dff90a-image.png

2.要统计最近 7 天每天的新增数据,按时间倒序排序

  • SELECT DATE_FORMAT(create_time,'%Y-%m-%d') AS TIME, COUNT(*) AS COUNT FROM test_t WHERE create_time >= DATE(NOW()) - INTERVAL 6 DAY GROUP BY DAY(create_time) ORDER BY create_time DESC;

5801efa0c1fc42ecb81f2e8fb497396f-image.png

3.要统计最近 7 天的新增数据,总计数据

  • SELECT * FROM test_t WHERE DATE_SUB(CURDATE(), INTERVAL 6 DAY) <= DATE(create_time) ORDER BY create_time DESC
    589d2709bad742e296b25c27a59aedc4-image.png

4.统计今日新增数据

  • SELECT * FROM test_t WHERE TO_DAYS(create_time) = TO_DAYS(NOW());
    10b312f6641548f382cc56ae2630c543-image.png

5.统计昨日新增数据
方法 1:

  • SELECT * FROM test_t WHERE TO_DAYS(NOW()) = 1 + TO_DAYS(create_time);
    209f1fccec3e444387d31dae04b5b2cd-image.png

方法 2: 取出昨天的和今天的记录过滤掉今天的记录

6.统计最近一周的数据
note: 最近一周不等于最近 7 天,一周是从周日开始算的,比如测试的时间是 2017-11-7,那么往前的一周就是 11-5 开始

  • SELECT * FROM test_t WHERE YEARWEEK(DATE_FORMAT(create_time,'%Y-%m-%d')) = YEARWEEK(NOW()) ORDER BY create_time DESC
    60d78eee9b9543da92cc1ac6aca04e19-image.png

7.统计最近一个月的数据
note: 最近一个月不等于最近 30 天

  • SELECT * FROM test_t WHERE create_time BETWEEN DATE_SUB(NOW(),INTERVAL 1 MONTH) AND NOW() ORDER BY create_time DESC
    df7dd728f84d4c3c8f43f1cef8036f96-image.png

8.统计上个月的数据

  • SELECT * FROM test_t WHERE PERIOD_DIFF(DATE_FORMAT(NOW() , '%Y%m') , DATE_FORMAT(create_time, '%Y%m')) = 1 ORDER BY create_time DESC
    1de438d4f8204d38afcd26a43c562e8e-image.png

9.统计本季度的数据

  • SELECT * FROM test_t WHERE QUARTER(create_time)=QUARTER(NOW()) ORDER BY create_time DESC
    7be4f3e72b3743c7bd9693a6e022479a-image.png

10.统计上个季度的数据

  • SELECT * FROM test_t WHERE QUARTER(create_time)=QUARTER(DATE_SUB(NOW(),INTERVAL 1 QUARTER)) ORDER BY create_time DESC
    d14d6c5a26e6469184f3eef3091a8107-image.png

11.统计今年的数据

  • SELECT * FROM test_t WHERE YEAR(create_time)=YEAR(NOW()) ORDER BY create_time DESC

54cca9b1ee834bbf8ec09425b69019c5-image.png

12.统计去年的数据

  • SELECT * FROM test_t WHERE YEAR(create_time)=YEAR(DATE_SUB(NOW(),INTERVAL 1 YEAR)) ORDER BY create_time DESC
    44672d8c79bb41ad95422f34044f1cdd-image.png
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 742 回帖
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    693 引用 • 537 回帖
  • 时间

    这世上唯一公平的东西就是时间。

    12 引用 • 111 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
c3gen
羡慕有什么用,你又不努力! 成都

推荐标签 标签

  • OneNote
    1 引用 • 3 回帖
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖
  • ngrok

    ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

    7 引用 • 63 回帖 • 644 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 391 关注
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 168 关注
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    335 引用 • 324 回帖
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 545 关注
  • 正则表达式

    正则表达式(Regular Expression)使用单个字符串来描述、匹配一系列遵循某个句法规则的字符串。

    31 引用 • 94 回帖 • 1 关注
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 731 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    31 引用 • 108 回帖 • 1 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 488 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 702 关注
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    52 引用 • 228 回帖
  • Windows

    Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

    226 引用 • 476 回帖
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    167 引用 • 595 回帖 • 1 关注
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    124 引用 • 74 回帖 • 1 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 618 关注
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    93 引用 • 901 回帖
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 503 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    159 引用 • 298 回帖
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    693 引用 • 537 回帖
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖 • 2 关注
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 87 关注
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 489 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    41 引用 • 130 回帖 • 249 关注
  • 国际化

    i18n(其来源是英文单词 internationalization 的首末字符 i 和 n,18 为中间的字符数)是“国际化”的简称。对程序来说,国际化是指在不修改代码的情况下,能根据不同语言及地区显示相应的界面。

    8 引用 • 26 回帖 • 1 关注