Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Usuwanie starych rekordów
Forum PHP.pl > Forum > Bazy danych > MySQL
mith
Witam

Mam taką bazę danych:

data:
2007-01-01 09:22:27
2006-05-15 21:14:18
2006-11-21 14:33:35

A mój problem polega na tym że nie wiem jak można zadać zapytanie aby usunąć wszystkie rekordy które są starsze o 3 miesiące licząc od aktualnej daty.

Za odpowiedzi dzięki z góry.
Cienki1980
Oblicz sobie w php datę 3 miesiące wstecz od dziś i podstaw do zapytania w taki sposób:
  1. <?php
  2. $obliczona_data; // data obliczona
  3.  
  4. $pyt="delete from table_name where date<'".$obliczona_data." 00:00:00'";
  5. ?>
mith
Dobra ale jeśli nie chciał bym w to mieszać php to jakie zadać zapytanie do sqla:

Próbowałem coś takiego:
  1. DELETE FROM tabela WHERE `data`<=NOW()-300000000


Ale coś nie bardzo to działa na miesiące, jak wstawiam mu np. 1 godzinę to działa elegancko.
Norbas
Przy założeniu, że miesiąc ma 30 dni:
  1. DELETE FROM tabela WHERE DATEDIFF(DATA,NOW())<-90
babejsza
  1. DELETE FROM tabela WHERE DATA <= NOW() - INTERVAL 3 MONTH
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.