经测试通过。
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');
参考资料:
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