我想从数据库中的特定表中删除时间戳超过180天的所有行。
我试过这个:
DELETE FROM on_search WHERE search_date < DATE_SUB(NOW(), INTERVAL 180 DAY);
但是删除了所有行,而不仅仅是超过6个月的行。
我在on_search表中有一个名为search_date的列,其中包含创建该行的时间。
search_id search_term search_date
660779 car games 1390052553
答案 0 :(得分:60)
DELETE FROM on_search
WHERE search_date < UNIX_TIMESTAMP(DATE_SUB(NOW(), INTERVAL 180 DAY))
答案 1 :(得分:51)
DELETE FROM on_search WHERE search_date < NOW() - INTERVAL N DAY
将N替换为您的日计数