百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> mysql查询在某个时间内的数据sql语句
分享文章到:

mysql查询在某个时间内的数据sql语句

发布时间:01/15 来源: 浏览: 关键词:
本文章来给在家介绍一个简单的mysql是查询在某个时间内的数据sql语句,希望结教程对各位朋友有所帮助。

比如我这边查询jz_user表用户创建时间大于四月一号到四月三十号为例

 代码如下

select FROM_UNIXTIME(create_time),user_id from jz_user Where DATE_FORMAT(FROM_UNIXTIME(create_time),'%Y-%m-%d') <= DATE_FORMAT("2013-4-30",'%Y-%m-%d') AND DATE_FORMAT(FROM_UNIXTIME(create_time),'%Y-%m-%d') >= DATE_FORMAT("2013-4-1",'%Y-%m-%d') 

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

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

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有12人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板