php+mysql 查询当天的所有数据

本文介绍了如何使用MySQL的UNIX_TIMESTAMP()和FROM_UNIXTIME()函数进行日期和时间戳的转换,并提供了查询当天、当周和当月数据的具体SQL语句。

经测试通过。

SELECT id FROM orders WHERE ordertime > unix_timestamp(curdate());

$start = date('Y-m-d 00:00:00');
$end = date('Y-m-d H:i:s');
SELECT id FROM orders WHERE ordertime >= unix_timestamp('start') AND ordertime <= unix_timestamp('$end');
php+mysql 查询当天的所有数据 - 临沂帆动网络公司 - 网站建设公司|网站排名优化
参考资料:

mysql日期函数From_unixtime及UNIX_TIMESTAMP及DATE_FORMAT(后者只能格式化标准日期格式,时间戳的不行)

from_unixtime()是MySQL里的时间函数
date为需要处理的参数(该参数是Unix 时间戳),可以是字段,也可以直接是Unix 时间戳字符串,后面的 '%Y%m%d' 主要是将返回值格式化。
例如:
mysql>SELECT FROM_UNIXTIME( 1249488000, '%Y%m%d' )  
->20071120
mysql>SELECT FROM_UNIXTIME( 1249488000, '%Y年%m月%d' )
->2007年11月20

UNIX_TIMESTAMP() 是与之相对正好相反的时间函数
UNIX_TIMESTAMP(), UNIX_TIMESTAMP(date)
若无参数调用,则返回一个 Unix timestamp ('1970-01-01 00:00:00' GMT 之后的秒数) 作为无符号整数。若用date来调用 UNIX_TIMESTAMP(),它会将参数值以'1970-01-01 00:00:00' GMT后的秒数的形式返回。date 可以是一个 DATE 字符串、一个 DATETIME字符串、一个 TIMESTAMP或一个当地时间的YYMMDD 或YYYMMDD格式的数字。
例如:
mysql> SELECT UNIX_TIMESTAMP() ; (执行使得时间:2009-08-06 10:10:40)
->1249524739
mysql> SELECT UNIX_TIMESTAMP('2009-08-06') ;
->1249488000
SELECT * FROM `student` WHERE regTime > UNIX_TIMESTAMP( curdate( ) ); //今天所有学生注册记录

原文出处:http://www.cnblogs.com/showker/archive/2010/03/18/1689054.html

=================================================

php mysql查询当天,查询本周,查询本月的数据(字段是时间戳)

其中 video 是表名;
createtime 是字段;
数据库time字段为时间戳。

查询当天:
$start = date('Y-m-d 00:00:00');
$end = date('Y-m-d H:i:s');
SELECT * FROM `table_name` WHERE `time` >= unix_timestamp('$start') AND `time` <= unix_timestamp('$end')

查询本周:
SELECT yearweek('2011-04-17 15:38:22') 结果是201115
SELECT yearweek('2011-04-17 15:38:22') 结果是201116
yearweek的第2个参数设置为1的原因是,中国人习惯把周1作为本周的第一天

另外补充下:
2011-04-17 是周日
SELECT dayofweek('2011-04-17 15:38:22') 查询出的是1,把礼拜天作为一周的第一天。
SELECT dayofweek('2011-04-18 15:38:22') 查询出的是2
SELECT weekday('2011-04-17 15:38:22') 查询出的是6,
SELECT weekday('2011-04-18 15:38:22') 查询出的是0,
所以建议使用weekday,查询出来的结果+1就可以了,就比较符合国人的习惯了。

SELECT * FROM `table_name` WHERE YEARWEEK( FROM_UNIXTIME( `time`, '%Y-%m-%d %H:%i:%s' ) ,1) = YEARWEEK( now( ),1 )

查询本月:
$start = date('Y-m-01 00:00:00');
$end = date('Y-m-d H:i:s');
SELECT * FROM `table_name` WHERE `time` >= unix_timestamp('$start') AND `time` <= unix_timestamp('$end);

查询本年:
$start = date('Y-01-01 00:00:00');
$end = date('Y-m-d H:i:s');
SELECT * FROM `table_name` WHERE `time` >= unix_timestamp('$start') AND `time` <= unix_timestamp('$end')

原文出处:http://blog.sina.com.cn/s/blog_ad1a579e01015jda.html
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

徐行致远

少侠,看你骨骼清奇,是个大善人

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值