无法比较MySQL中的字符串

时间:2011-08-25 19:44:36

标签: php mysql

我在我的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;
        }
    }

3 个答案:

答案 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周”);