Foros del Web » Programando para Internet » PHP »

Error ordenando por fecha

Estas en el tema de Error ordenando por fecha en el foro de PHP en Foros del Web. Buenas,es la primera vez que posteo,pero la verdad es que siempre leo el foro y me ha sacado ya de muchos problemas. Gracias al php ...
  #1 (permalink)  
Antiguo 16/07/2008, 05:45
 
Fecha de Ingreso: julio-2008
Mensajes: 2
Antigüedad: 15 años, 9 meses
Puntos: 0
Error ordenando por fecha

Buenas,es la primera vez que posteo,pero la verdad es que siempre leo el foro y me ha sacado ya de muchos problemas.

Gracias al php he conseguido ya programar varias cosas para mi web,es la primera vez que pido ayuda ya que al usar el buscador no encuentro nada -.-"

Busqué información ,y mediante el DATE_FORMAT() imprimo los resultados como dd-mm-aaaa de la base de datos almacenados en el formato aaaa-mm-dd en la misma.

El problema es que no consigo ordenar una consulta mediante la fecha ya que solo las ordena por dia,al llegar al primer guión para y por tanto se mezcla el año 2007 con 2008.

¿Como puedo solucionar esto?

Gracias por la ayuda
  #2 (permalink)  
Antiguo 16/07/2008, 06:40
Avatar de JoniJnm  
Fecha de Ingreso: mayo-2007
Ubicación: Madrid
Mensajes: 264
Antigüedad: 16 años, 11 meses
Puntos: 4
Respuesta: Error ordenando por fecha

Creo que esto:

SELECT DATE_FORMAT(`tu_campo_date`,'%d/%m/%Y') AS my_date FROM tu_tabla ORDER BY my_date ASC

Sino, inserta un campo que muestre el mktime de las fechas, lo ordenas por él, pero recoges el valor del campo de la fecha.

SELECT campo_fecha FROM tu_tabla ORDER BY campo_mktime ASC

Y para hacer el mkite, haces un campo en la tabla (y uno espacio vacío en cada fila:
en un txt copias la tabla, reemplazas '); por ','');

Luego:

Código PHP:
$id mysql_query("SELECT id FROM tu_tabla ORDER BY id DESC LIMIT 1");
$id mysql_fetch_array($id);
$id $id[0];

for (
$i=0;$i<$id;$i++) {
$var mysql_query("SELECT campo_date FROM tu_tabla where id='".$i."'");
$var mysql_fetch_array($var);
$var explode("-",$var[0]);

$var mktime("0","0","0",$var[1],$var[2],$var[0]);

mysql_query("update from tu_tabla set campo_maktime='".$var."' where id='".$i."'";



Última edición por JoniJnm; 16/07/2008 a las 07:01
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 00:12.