MySQL获取某个时间范围内的数据

TO_DAYS(date)函数与now()函数
服务器君一共花费了224.747 ms进行了5次数据库查询,努力地为您提供了这个页面。
试试阅读模式?希望听取您的建议

有这样一个需求,我们需要获得某个时间段内所有数据记录,比如最近一个月内的新闻,然后再在这个数据集合中进行排序,看哪个新闻的点击率最高。现在问题是,如何获得那个时间段。MySQL已经有些函数可以帮助我们,先看看这些函数吧。

TO_DAYS(date) 函数

给定一个日期date,返回一个天数(从年份0开始的天数)。

比如下面的例子:

mysql> SELECT TO_DAYS('2009-08-07');
+-----------------------+
| TO_DAYS('2009-08-07') |
+-----------------------+
|                733991 |
+-----------------------+
1 row in set

TO_DAYS() 不用于阳历出现(1582)前的值,原因是当日历改变时,遗失的日期不会被考虑在内。

请记住,MySQL“日期和时间类型”中的规则将日期中的二位数年份值转化为四位。例如,‘2010-08-07′和 ‘10-08-07′ 被视为同样的日期:

mysql> SELECT TO_DAYS('2009-08-07'),TO_DAYS('09-08-07');
+-----------------------+---------------------+
| TO_DAYS('2009-08-07') | TO_DAYS('09-08-07') |
+-----------------------+---------------------+
|                733991 |              733991 |
+-----------------------+---------------------+
1 row in set

对于1582年之前的日期(或许在其它地区为下一年),该函数的结果实不可靠的。

now() 函数

NOW() 函数返回当前的日期和时间。

mysql> select (now());
+---------------------+
| (now())             |
+---------------------+
| 2010-08-26 21:18:44 |
+---------------------+
1 row in set

to_days(current_date)也可以实现上面的功能。

mysql> select to_days(current_date);
+-----------------------+
| to_days(current_date) |
+-----------------------+
|                734375 |
+-----------------------+
1 row in set

结果

现在我们可以得出问题的答案了:

select * from news where to_days(now())-to_days(newsdate) < 30 order by view desc limit 0, 10

可以获得一个月内浏览数最高的十条记录。

本文地址:http://www.nowamagic.net/librarys/veda/detail/415,欢迎访问原出处。

不打个分吗?

转载随意,但请带上本文地址:

http://www.nowamagic.net/librarys/veda/detail/415

如果你认为这篇文章值得更多人阅读,欢迎使用下面的分享功能。
小提示:您可以按快捷键 Ctrl + D,或点此 加入收藏

大家都在看

阅读一百本计算机著作吧,少年

很多人觉得自己技术进步很慢,学习效率低,我觉得一个重要原因是看的书少了。多少是多呢?起码得看3、4、5、6米吧。给个具体的数量,那就100本书吧。很多人知识结构不好而且不系统,因为在特定领域有一个足够量的知识量+足够良好的知识结构,系统化以后就足以应对大量未曾遇到过的问题。

奉劝自学者:构建特定领域的知识结构体系的路径中再也没有比学习该专业的专业课程更好的了。如果我的知识结构体系足以囊括面试官的大部分甚至吞并他的知识结构体系的话,读到他言语中的一个词我们就已经知道他要表达什么,我们可以让他坐“上位”毕竟他是面试官,但是在知识结构体系以及心理上我们就居高临下。

所以,阅读一百本计算机著作吧,少年!

《C专家编程》 林登 (LinDen.P.V.D) (作者), 徐波 (译者)

《C专家编程》展示了最优秀的C程序员所使用的编码技巧,并专门开辟了一章对C++的基础知识进行了介绍。书中C的历史、语言特性、声明、数组、指针、链接、运行时、内存以及如何进一步学习C++等问题进行了细致的讲解和深入的分析。全书撷取几十个实例进行讲解,对C程序员具有非常高的实用价值。《C专家编程》可以帮助有一定经验的C程序员成为C编程方面的专家,对于具备相当的C语言基础的程序员,《C专家编程》可以帮助他们站在C的高度了解和学习C++。

更多计算机宝库...