Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   Como eliminar los registros de hace seis horas (https://www.clubdelphi.com/foros/showthread.php?t=13534)

salvica 22-08-2004 23:00:56

Como eliminar los registros de hace seis horas
 
Hola forer@s,

Tengo una tabla (en MySql) en la que almaceno información cada cierto tiempo, y deseo eliminar aquellos que tienen una antiguedad de 6 ú 8 horas, pero me trabo con los campos fecha :mad:

La tabla la creo tal que asi:
Código SQL [-]
    CREATE TABLE IF EXISTS la_dichosa_tabla (
          id_registro    INTEGER     NOT NULL AUTO_INCREMENT,
          .....
          fecha          DATETIME    NOT NULL,
          leido          CHAR(1)     NOT NULL DEFAULT "0",
          procesado      CHAR(1)     NOT NULL DEFAULT "0",
          PRIMARY KEY (id_registro)
 );
Bién, ahora se trataría de eliminar los registros viejos
Código SQL [-]
 DELETE FROM la_dichosa_tabla
       WHERE fecha< ¿?  aquí me pierdo
         AND leido="1"
         AND procesado="1";
Gracias por la ayuda que podais prestarme

Sirkius 23-08-2004 09:16:21

No te recomiendo usar un DateTime porque las funciones que hay disponibles son solo para Date y para Time, y cuando pasas un DateTime se desprecia la parte que no quieres. Donde veo el problema es en cambios de día...

En definitiva, yo usaría un timestamp que para este caso es muy sencillito lo que tienes q hacer.

salvica 23-08-2004 16:53:11

Gracias Sirkius

El utilizar campos DateTime proviene de que aunque la información la guardo en Base de Datos de MySql, utilizo tres lenguajes diferentes para tratarla:
1º - Delphy/Kylix para obtenerla y crear las Querys
2º - SQL (creadas en el paso 1º) para transmitirla
3º - PHP para transformarla en HTML (utilizando mktime)
por lo que lo más estandard entre los tres son campos DateTime.

Inicialmente habia pensado algo como "SYSDATE() - CANTIDAD", el problema es que no sé como calcular el valor de esa variable (CANTIDAD), ya que tengo entendido que SYSDATE() devuelve la fecha y hora del sistema (por ejemplo "2004-08-22 20:19:22")

Vale :D , según te lo estaba escribiendo (lo que está en rojo), creo que dado con la solución :D :D :D
Código SQL [-]
DELETE FROM la_dichosa_tabla
 WHERE UNIX_TIMESTAMP( fecha ) <  UNIX_TIMESTAMP( "2004-08-22 18:00:00" )
   AND leido = "1"
   AND procesado = "1";
Lo miraré a ver si "rula" como deseo, de todas formas se siguen esperando más ideas.
Saludazos
Salvica

Sirkius 23-08-2004 17:02:07

Código:

UNIX_TIMESTAMP(fecha) < (UNIX_TIMESTAMP()-6*3600)
Así te ahorras tener que crear la sentencia SQL cada vez diferente y la tienes fija.

Saludos

salvica 23-08-2004 19:02:44

Gracias de nuevo Sirkius

Solución corta y sencilla


La franja horaria es GMT +2. Ahora son las 04:51:58.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi