我有字段date
在我的MySQL数据库作为一个字符串,我想比较它在MySQL查询的另一个字符串,以获得一个星期内的用户最近的活动。但是由于某种原因,我没有从fetch_assocs返回数据。
$week = uk_date();
echo $week . " - ---------- -";
$week = $week - (60*24*7);
echo $week;
$array = array();
$q = mysql_query("SELECT * FROM Posts WHERE `date` > " . $week . "") or die(mysql_error());
if (!$q) {}
if (mysql_num_rows($q) < 1) {
}
else {
while ($row = mysql_fetch_assoc($q)) {
$array['posts'][] = $row;
}
}
$q = mysql_query("SELECT * FROM Comments WHERE `date` > " . $week . "") or die(mysql_error());
if (mysql_num_rows($q) < 1) {
}
else {
while ($row = mysql_fetch_assoc($q)) {
$array['comments'][] = $row;
}
}
$q = mysql_query("SELECT * FROM Likes WHERE `date` > " . $week . "") or die(mysql_error());
if (mysql_num_rows($q) < 1) {
}
else {
while ($row = mysql_fetch_assoc($q)) {
$array['likes'][] = $row;
}
}
"我有字段日期在我的MySQL数据库作为一个字符串,"…您的日期字段是字符/varchar/文本?这意味着您将无法直接进行日期/时间计算,因为您没有使用日期/时间值。如果您在字段中存储日期,那么将该字段设置为日期或日期时间类型。
然后你可以这样做:
SELECT ... FROM ... WHERE `datefield` > DATE_SUB(now(), INTERVAL 1 WEEK)
在PHP中根本不用计算星期-这是数据库可以做的事情,例如
SELECT * FROM Comments WHERE date > date_sub(CUR_DATE(), interval 7 day);
参见http://dev.mysql.com/doc/refman/5.5/en/date-and-time-functions.html#function_datediff了解MySQL日期操作的魔力
代替简单的日期尝试使用STR_TO_DATE(date
)在mysql查询和一周尝试使用PHP函数strtotime(-1 week);