Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Kasowanie wpisow starszych niz xx dni
Forum PHP.pl > Forum > Bazy danych > MySQL
lucek
Mam formularz a w nim pole input o nazwie "dni".

Jak zadac zapytanie do bazy aby skasowalo rekordy starsze niz liczba dni wpisana w formularz.
Np. jak wpisze 5 - dto powinny zostac saksowane wszystkie rekordy ktore byly napisane wczesniej niz 5 dni temu.

Date w bazie mam formacie unixowym - timestamp.
Z gory dzieki za pomoc.
halfik
[php:1:57bcef5340]
$older = 5;
$time = time()-($older*24*60*60);
$query = "DELETE FROM tabela WHERE czas<=$time";
@mysql_query($query);
[/php:1:57bcef5340]
radzaw
[php:1:b630c842c5]<?php
mysql_query("DELETE FROM tabela WHERE czas < ".(time() - $dni*86400));
?>[/php:1:b630c842c5]

lub zmien unixowego timestampa na 'date'/'datetime' i wtedy mysql ma duzo funkcji do obslugi czasu winksmiley.jpg
np.
[sql:1:b630c842c5]DELETE FROM tabela WHERE TIMESTAMPADD(DAY, $dni, czas) < NOW()[/sql:1:b630c842c5]
lucek
Wielkie dzieki za pomoc.
Zastosowalem ten kod:
[php:1:862b0d4ff4]<?php
$older = 5;
$time = time()-($older*24*60*60);
$query = "DELETE FROM tabela WHERE czas<=$time";
@mysql_query($query);

echo"<br><center><font color=#FF0000><b>Ogłoszenia spełniaj&plusmn;ce kryterium zostały usunięte !!!</b></font><br><br>";
echo"<head><meta http-equiv="refresh" content="1;url=?go=ksiega"></head>";
?>[/php:1:862b0d4ff4]

I jeszcze pytanko: czy da sie wysietlic w komunikacie ID wszystkich skasowanych wpisow - powiedzmy oddzielone przecinkami questionmark.gifquestionmark.gifquestionmark.gif
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.