创建昨天的时间戳,并将该范围内的所有时间戳分组


create a timestamp for yesterday and group all of the timestamps within that range

我有一个充满数据的数据库,其中也有一个时间戳字段。我要做的是计算按时间戳分组的字段中记录的数量,但四舍五入到以天为单位。

我现在有一段代码如下,

$days_ago7a = date('Y-m-d', mktime(0, 0, 0, date("m") , date("d") - 7, date("Y")));
$result = mysql_query("SELECT * FROM all_count WHERE date='$days_ago7a'");
$num_rows37 = mysql_num_rows($result);

我想做同样的事情,只是用时间戳(也在数据库中)替换日期,并将24小时内的所有时间戳分组。

这可能吗?

OK,所以我已经改变了代码,但它不返回任何结果?

$result = mysql_query("select date( timestamp ), count(*) from all_count group by date(   timestamp );") 
 or die(mysql_error());  
  while($row = mysql_fetch_array( $result )) { 
  echo "$timestamp";
  }

按时间戳的日期分组:

select date( timestampfield ), count(*) from all_count group by date( timestampfield );

获取昨天的计数:

select count(*) from all_count where date(timestampfield) = date_sub( curdate(), INTERVAL 1 day );

我想在日期(而不是时间)范围内使用时间戳的更简单的方法是这样做:

$date = '2012-05-20 11:25:12';
$date = strtotime($date);
$begginingOfDay = date('Y', $date).'-'.date('m', $date).'-'.date('d', $date).' 00:00:00'
$timestamp = strtotime($begginingOfDay);

现在您的$timestamp包含一天开始的时间戳。然后你可以移动它,例如减去几天:

//timestamp points to 2012-05-20 00:00:00
$timestampWeekBefore = $timestamp - 7 * 24 * 60 * 60; //date - 7 days * 24 hours * 60 minutes * 60 seconds

会得到2012-05-14 00:00:00。操作完成后,您可以使用适当的格式调用date来放置在您的页面或查询中。

MySQL日期函数的拯救!

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

mysql> SELECT TO_DAYS(950501);
    -> 728779
mysql> SELECT TO_DAYS('2007-10-07');
    -> 733321

我想你可以把剩下的弄明白。