Foros del Web » Programando para Internet » PHP »

borrar tablas datos con condicion

Estas en el tema de borrar tablas datos con condicion en el foro de PHP en Foros del Web. Hola, al final siempre acudo aqui por si me podeis ayudar. tengo una bd que quiero limpiar y no se como hacerlo, os explico tengo ...
  #1 (permalink)  
Antiguo 02/10/2010, 11:47
 
Fecha de Ingreso: febrero-2002
Mensajes: 37
Antigüedad: 22 años, 2 meses
Puntos: 0
borrar tablas datos con condicion

Hola, al final siempre acudo aqui por si me podeis ayudar.

tengo una bd que quiero limpiar y no se como hacerlo, os explico

tengo una tabla que se llama usere, donde uno de sus campos es card_date, este contiene la fecha de creacion del usere en cuestion y los datos que contiene son este formato 2009-12-21 00:34:53

necesito borrar todos los datos anteriores a por ejemplo 2010-06-31 para asi poder limpiar la bd.
coloco esta consulta:

SELECT * FROM usere WHERE card_date < "2010-06-31"

¿es correcta? a mi me da resultados en pantalla

pero cuando intento borrar coloco

DELETE * FROM usere WHERE card_date < "2009-12-31"

y me da error el sql ¿que estoy haciendo mal?

muchas gracias por vuestra ayuda y tiempo.

Saludos

Merche
  #2 (permalink)  
Antiguo 02/10/2010, 11:52
Avatar de Miguelithox  
Fecha de Ingreso: diciembre-2008
Ubicación: Viña del Mar
Mensajes: 287
Antigüedad: 15 años, 3 meses
Puntos: 7
Respuesta: borrar tablas datos con condicion

Por eso siempre se debe ocupar la función time() para las fechas y luego cuando las muestras le das formato con la otra función date()

Por ejemplo si quieres borrar lo tuyo con la función time(), quedaría así:
Código PHP:
mysql_query("DELETE FROM usere WHERE " time() . " > card_date"); 
  #3 (permalink)  
Antiguo 02/10/2010, 12:16
 
Fecha de Ingreso: febrero-2002
Mensajes: 37
Antigüedad: 22 años, 2 meses
Puntos: 0
Respuesta: borrar tablas datos con condicion

dentro de los parentesis de Time pongo la fecha pero me error de nuevo

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '"SELECT FROM vcard_userecard WHERE " . time(2009-12-31) . " > card_date"' at line 1

Gracias
  #4 (permalink)  
Antiguo 02/10/2010, 12:29
Avatar de Miguelithox  
Fecha de Ingreso: diciembre-2008
Ubicación: Viña del Mar
Mensajes: 287
Antigüedad: 15 años, 3 meses
Puntos: 7
Respuesta: borrar tablas datos con condicion

Dentro de los paréntesis de time no debes colocar nada, sólo te estoy dando un ejemplo si en el caso de que uses la función TIME() cuando envías o guardas en la base de datos, es de esa forma, por eso es mejor que te cambies de formato de fecha.
  #5 (permalink)  
Antiguo 02/10/2010, 12:38
 
Fecha de Ingreso: febrero-2002
Mensajes: 37
Antigüedad: 22 años, 2 meses
Puntos: 0
Respuesta: borrar tablas datos con condicion

Gracias por tu pronta respuesta,

pero yo de bases de datos entiendo muy poquito, y he visto que tengo entradas superviejas en mi bd y queria borrarlas, por eso he estado buscando informacion por google, y habia llegado a esa conclusion, pero no me funciona, por ese motivo entre a pedir ayuda, no se que funcion usa para guardar los datos, solo se el formato una vez guardados, seguire mirando por ahi y haciendo pruebas hasta solucionarlo, no obstante te estoy muy agradecida.

Un abrazo

Merche
  #6 (permalink)  
Antiguo 02/10/2010, 12:42
Avatar de Miguelithox  
Fecha de Ingreso: diciembre-2008
Ubicación: Viña del Mar
Mensajes: 287
Antigüedad: 15 años, 3 meses
Puntos: 7
Respuesta: borrar tablas datos con condicion

Mira en la función en donde guardas las entradas, y date cuenta que hay una función llamada date("Y-m-d H:i:s", time());
cambia eso por time() solamente y te quedarán solamente números, luego si quieres darle formato para que otras personas lo vean hazlo nuevamente con la función date: date("Y-m-d H:i:s", time());

Etiquetas: borrar, tablas
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 15:39.