我在我的MySQL数据库中有字段date
作为字符串,我想将它与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;
}
}
答案 0 :(得分:0)
“我的MySQL数据库中的字段日期为字符串,”...您的日期字段是char / varchar / text?这意味着您将无法进行直接日期/时间计算,因为您没有使用日期/时间值。如果要在字段中存储日期,请将该字段设置为日期或日期时间类型。
然后你可以做类似的事情:
SELECT ... FROM ... WHERE `datefield` > DATE_SUB(now(), INTERVAL 1 WEEK)
答案 1 :(得分:0)
根本不计算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 Date操作的神奇之处。
答案 2 :(得分:-1)
而不是简单的日期尝试在mysql查询中使用STR_TO_DATE(date
)并且一周尝试使用
php函数strtotime(“ - 1周”);