drob50257447 2015-12-30 17:37
浏览 52
已采纳

Mysql和PHP检查是否存在名称和最后联系日期

I have several names and dates in my database, and I am looking for a way to only view an individual's name once and only show that name if their last date of contact was more than 6 months ago.

I know how to view an entry only once using:

$xyz= $db->query("SELECT * FROM dbname GROUP BY name"); 

and i also know how to view a date of less than 6 months using:

if (strtotime($xyz['date']) <= strtotime("-6 months")) {
    do stuff;
}

but I just can not figure out a way to combine them.

  • 写回答

4条回答 默认 最新

  • dongqing904999 2015-12-30 19:26
    关注

    In addition to SKY's orig. answer, you want the MAX (most recent) date to be < (older than) 6 mo.

    You likely won't need to GROUP BY with this method as only one row should have the max date.

    SELECT * 
    FROM dbname a
    WHERE dateCol < DATE_SUB(now(), INTERVAL 6 MONTH) 
      AND dateCol = (SELECT MAX(dateCol)
                     FROM dbname b
                     WHERE b.name = a.name)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算