1

我已经搜索过这个,但我找不到任何东西。

我有一个文章表。当我写新文章时,我使用 php time() 函数将时间写入 mysql 表。

我的桌子是

id文章时间

时间数据类型为 INT(UNSIGNED)

我的问题是我想显示上周到今天或上个月到今天的文章。

我的mysql查询应该如何?

通常我这样做

SELECT * FROM articles ORDER BY Time DESC

所以这给了我从今天到过去的数据。我该怎么做?我想不出解决办法。我应该一起使用 php-mysql 还是只能用 mysql 来处理?你能给我想法或例子吗?谢谢。

编辑:

我按照建议更改为日期时间,现在我认为我有时区问题

现在我的 ago() 函数工作晚了 2 小时。

<?php 
date_default_timezone_set('Europe/Istanbul'); //timezone function 
ago($time)
{
   $periods = array("saniye", "dakka", "saat", "gün", "hafta", "ay", "yıl", "baya");
   $lengths = array("60","60","24","7","4.35","12","10");

   $now = time();

       $difference     = $now - $time;
       $tense         = "önce";

   for($j = 0; $difference >= $lengths[$j] && $j < count($lengths)-1; $j++) {
       $difference /= $lengths[$j];
   }

   $difference = round($difference);

   return "$difference $periods[$j] önce ";
} //ago function 

echo $Date = ago(strtotime($data['WriteTime'])). 'önce';
?>
4

3 回答 3

1

好吧,您在使用 unix 时间戳整数存储在数据库中时犯了一个初学者错误。您应该几乎总是使用日期/日期时间字段类型,因为您总是需要查询那些在不使用 unix 时间戳时更容易的字段。

NOW()因此,将您的字段转换为日期时间,在添加行时使用 MySQL将当前时间戳插入字段。

然后查看 MySQL 数据/时间函数以根据您的意愿查询该字段。

http://dev.mysql.com/doc/refman/5.5/en/date-and-time-functions.html

于 2013-01-24T20:57:07.143 回答
1

假设您的time列是 Unix 时间戳,您可以尝试这样的事情:(未测试)

SELECT ... 
FROM magic
WHERE `time` BETWEEN DATE_SUB(FROM_UNIXTIME(`time`), INTERVAL 1 WEEK) AND NOW()

对于您的月份,您将使用INTERVAL 1 MONTH. 请将您的列转换为常用数据类型,并且不要使用保留字作为列名。

于 2013-01-24T20:55:08.540 回答
1

首先制作time一个date type field (并给它一个有意义的不同名称article_date,例如例如)

然后使用这个查询:

SELECT  * FROM    articles 
WHERE   article_date BETWEEN CURDATE() - INTERVAL 7 DAY AND CURDATE()
于 2013-01-24T20:55:21.820 回答