在MySQL中比较字符串有问题


Trouble comparing strings in MySQL

我有字段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);