Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 22-08-2004
Avatar de salvica
salvica salvica is offline
Miembro
 
Registrado: mar 2004
Ubicación: Albacete (España) ... En un lugar de la Mancha ...
Posts: 304
Poder: 21
salvica Va por buen camino
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

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
Responder Con Cita
  #2  
Antiguo 23-08-2004
Sirkius Sirkius is offline
Miembro
 
Registrado: jun 2004
Posts: 83
Poder: 20
Sirkius Va por buen camino
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.
Responder Con Cita
  #3  
Antiguo 23-08-2004
Avatar de salvica
salvica salvica is offline
Miembro
 
Registrado: mar 2004
Ubicación: Albacete (España) ... En un lugar de la Mancha ...
Posts: 304
Poder: 21
salvica Va por buen camino
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 , según te lo estaba escribiendo (lo que está en rojo), creo que dado con la solución
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
Responder Con Cita
  #4  
Antiguo 23-08-2004
Sirkius Sirkius is offline
Miembro
 
Registrado: jun 2004
Posts: 83
Poder: 20
Sirkius Va por buen camino
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
Responder Con Cita
  #5  
Antiguo 23-08-2004
Avatar de salvica
salvica salvica is offline
Miembro
 
Registrado: mar 2004
Ubicación: Albacete (España) ... En un lugar de la Mancha ...
Posts: 304
Poder: 21
salvica Va por buen camino
Gracias de nuevo Sirkius

Solución corta y sencilla
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 20:47:38.


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
Copyright 1996-2007 Club Delphi