douqiao1413 2011-08-25 19:44
浏览 72
已采纳

无法比较MySQL中的字符串

I have the field date in my MySQL DB as a string, and I want to compare it to another string in a MySQL query to get the recent activity for a user within a week. But for some reason I am getting no returned data from the fetch_assocs.

Please can you tell me where I am going wrong?

$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条回答 默认 最新

  • drn1008 2011-08-25 19:48
    关注

    "I have the field date in my MySQL DB as a string,"... your date field is a char/varchar/text? That means you will NOT be able to do direct date/time calculations, because you're not using date/time values. If you're storing dates in a field, then make that field a date or datetime type.

    Then you can do stuff like:

    SELECT ... FROM ... WHERE `datefield` > DATE_SUB(now(), INTERVAL 1 WEEK)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘