drfkl66684 2012-10-24 23:47
浏览 127
已采纳

MYSQL多表删除

I have 2 tables setup like this:

Items:
   id (int)
   name (varchar)
   category (int)
   last_update (timestamp)

Categories
   id (int)
   name (varchar)
   tree_id (int)

I want to delete all the records from Items, who's last_update is NOT today, and who's corresponding categories.tree_id is equal to 1. However, I don't want to delete anything from the Categories table, just the Items table. I tried this:

$query = "DELETE FROM items USING categories, items
    WHERE items.category = categories.id
    AND categories.tree_id = 1
    AND items.last_update != '".date('Y-m-d')."'";

However this just seems to delete EVERY record who's tree_id is 1. It should keep items with a tree_id of 1, as long as their last_update field is today

What am I missing?

  • 写回答

3条回答 默认 最新

  • doufangxian4985 2012-10-24 23:54
    关注

    You say that last_update contains time-stamps - I assume UNIX time-stamp. You can never find a record with the same time-stamp as when the stamp was executed and you can not compare a time-stamp with formatted date, they'll never correspond. So you need to store the data in last_update column in a date(Y-m-d) format so that compare those which are not equal.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 IAR程序莫名变量多重定义
  • ¥15 (标签-UDP|关键词-client)
  • ¥15 关于库卡officelite无法与虚拟机通讯的问题
  • ¥15 qgcomp混合物线性模型分析的代码出现错误:Model aliasing occurred
  • ¥100 已有python代码,要求做成可执行程序,程序设计内容不多
  • ¥15 目标检测项目无法读取视频
  • ¥15 GEO datasets中基因芯片数据仅仅提供了normalized signal如何进行差异分析
  • ¥100 求采集电商背景音乐的方法
  • ¥15 数学建模竞赛求指导帮助
  • ¥15 STM32控制MAX7219问题求解答