Foros del Web » Programando para Internet » PHP »

Consultas relacionadas. Ayuda por favor.

Estas en el tema de Consultas relacionadas. Ayuda por favor. en el foro de PHP en Foros del Web. Bien... no se si voy a ser capaz de explicar esto... Bueno, el caso es que yo tengo una tabla en MySQL con la siguiente ...
  #1 (permalink)  
Antiguo 31/01/2002, 12:16
Avatar de lical
Colaborador
 
Fecha de Ingreso: diciembre-2001
Ubicación: $PWD
Mensajes: 1.267
Antigüedad: 16 años
Puntos: 0
Consultas relacionadas. Ayuda por favor.

Bien... no se si voy a ser capaz de explicar esto... Bueno, el caso es que yo tengo una tabla en MySQL con la siguiente estructura:

id - int
titulo - varchar
fecha - datetime
usuario - varchar
dependiente - varchar
mensaje - blob
categoría - int

Bueno, el caso es que esta tabla contiene los mensajes (y sus respuestas) de un foro. El campo id es el número de mensaje, y para los mensajes el campo dependiente vale cero y para las respuestas vale el número de id del mensaje original.

Entonces yo en una página PHP imprimo los titulos de los mensajes solamente, ordenados por fecha y desde 10 dias atras. Pero la cuestión está en que la consideración de la fecha solo tiene en cuenta los mensajes, y no las respuestas a esos mensajes para ordenarlos por fecha. Creo que se entiende lo que planteo, ¿no?

Yo quiero que tenga en cuenta las fechas de las respuestas también a la hora de ordenar los mensajes. Lo que yo tengo actualmente es:

"SELECT * FROM mensajes WHERE dependiente = 0 AND categoria = '$categoria' AND fecha BETWEEN '$fecha_completa' AND NOW() ORDER BY fecha DESC"

Y luego los saco con algo como:
while ($row=mysql_fetch_row($query)) {
imprimo una tabla con los valores de $row[];
}


¿A alguien se le ocurre cómo puedo hacer para que al ordenar los mensajes tenga también en cuenta la fecha de sus respuestas?

Un saludo y de veras agradezco cualquier sugerencia, porque estoy realmente atascado. :)

______________
¿Piensas que el software puede ser algo mas?
<a href="http://www.zonasiete.org/" target="_blank">www.zonasiete.org</a>
Acercando el proyecto GNU/Linux a todos.
  #2 (permalink)  
Antiguo 31/01/2002, 12:57
Avatar de Webstudio
Colaborador
 
Fecha de Ingreso: noviembre-2001
Ubicación: 127.0.0.1
Mensajes: 3.499
Antigüedad: 16 años, 1 mes
Puntos: 68
Re: Consultas relacionadas. Ayuda por favor.

No lo probé y es posible (es más es muy posible) que no funcione, pero te puede dar una idea de como encaminarte:

SELECT dependiente FROM mensajes WHERE AND (categoria = '$categoria') AND (fecha BETWEEN '$fecha_completa' AND NOW()) GROUP BY dependiente ORDER BY fecha DESC;

Fijate, es una idea, de esta manera podés obtener los ID de los mensajes creadores de discusion, ordenador por fecha descendiente de respuesta.

Todo esto sin entrar a un LEFT JOIN entre la misma tabla consigo misma para poder obtener los nombres de los mensajes.

cualquier cosa, preguntanos.



<hr><font size=2 face="verdana">- Pablo Daniel Rigazzi (Webstudio)
<font size=1 color="#333333">COORDINADOR PROYECTO REGIONALIZACION ARGENTINA
Visita <a href="http://www.web-studio.com.ar" target="_blank">Web Studio</a> - Tutoriales Photoshop</fo
  #3 (permalink)  
Antiguo 31/01/2002, 16:47
Avatar de lical
Colaborador
 
Fecha de Ingreso: diciembre-2001
Ubicación: $PWD
Mensajes: 1.267
Antigüedad: 16 años
Puntos: 0
Re: Consultas relacionadas. Ayuda por favor.

Gracias Webstudio... A ver... Tu me has puesto esto:

&quot;SELECT dependiente FROM mensajes WHERE AND (categoria = '$categoria') AND (fecha BETWEEN '$fecha_completa' AND NOW()) GROUP BY dependiente ORDER BY fecha DESC&quot;;

Pues aquí me pierdo más o menos porque no sé cuál va a ser la salida que va a tener esta consulta (aparte ¿puede faltar algo entre WHERE y AND?). Si no me equivoco esto va a tener la salida de un solo campo.... el campo dependiente, creo, pero tampoco termino de entender la consulta que me planteas.

¿Tendría que hacer después otra? Es que aparte tengo que seleccionar un UNIX_TIMESTAMP del campo fecha, como tú me dijiste... Y a parte de que no entiendo la consulta que me pones... no sé cómo quedaría con el UNIX_TIMESTAMP que necesito para fecha.

Por favor, Webstudio, aclarame un poquito esto, lo necesito, no creo que pueda salir de aqui yo solo.

Cualquier otra persona que pueda aportar algo por favor que lo haga.

Un saludo y muchas gracias :)

______________
¿Piensas que el software puede ser algo mas?
<a href="http://www.zonasiete.org/" target="_blank">www.zonasiete.org</a>
Acercando el proyecto GNU/Linux a todos.
  #4 (permalink)  
Antiguo 01/02/2002, 08:46
Avatar de Webstudio
Colaborador
 
Fecha de Ingreso: noviembre-2001
Ubicación: 127.0.0.1
Mensajes: 3.499
Antigüedad: 16 años, 1 mes
Puntos: 68
Re: Consultas relacionadas. Ayuda por favor.

Tienes razón, en realidad, el query es:

SELECT dependiente FROM mensajes WHERE (categoria = '$categoria') AND (fecha BETWEEN '$fecha_completa' AND NOW()) GROUP BY dependiente ORDER BY fecha DESC;

Lo que se supone que haría este query es:

1) ORDERNAR POR fecha descendiente todos los mensajes.
2) Sacar todos los que no estén en el rango de fecha indicada en $fecha_completa
3) Dejar solamente los que sean de categoria $categoria.
4) De todos esos mensajes, solo te va a devolver los id de Mensaje Dependiente (mensaje que originó el tópico), sin repetir. (GROUP BY).

Saludos.

<hr><font size=2 face="verdana">- Pablo Daniel Rigazzi (Webstudio)
<font size=1 color="#333333">COORDINADOR PROYECTO REGIONALIZACION ARGENTINA
Visita <a href="http://www.web-studio.com.ar" target="_blank">Web Studio</a> - Tutoriales Photoshop</fo
  #5 (permalink)  
Antiguo 01/02/2002, 10:02
Avatar de lical
Colaborador
 
Fecha de Ingreso: diciembre-2001
Ubicación: $PWD
Mensajes: 1.267
Antigüedad: 16 años
Puntos: 0
Re: Consultas relacionadas. Ayuda por favor.

Vamos a ver si ya lo entendi:

Esta consulta devuelve una lista de los id de los mensajes ordenados descendientemente por fecha teniendo en cuenta la fecha de las respuestas, ¿no?

Entonces yo tendria que mostrar por pantalla los mensajes segun el orden que me devuelve esta consulta....

¿Me estoy equivocando? ¿Lo entendi por fin?

Muchas gracias de nuevo :)

______________
¿Piensas que el software puede ser algo mas?
<a href="http://www.zonasiete.org/" target="_blank">www.zonasiete.org</a>
Acercando el proyecto GNU/Linux a todos.
  #6 (permalink)  
Antiguo 01/02/2002, 10:54
Avatar de lical
Colaborador
 
Fecha de Ingreso: diciembre-2001
Ubicación: $PWD
Mensajes: 1.267
Antigüedad: 16 años
Puntos: 0
Re: Consultas relacionadas. Ayuda por favor.

Creo que lo voy entendiendo . Simplifiquemos la consulta (porque los otros parámetros ya me acuerdo de añadirselos después). Quedaría algo como:

&quot;SELECT dependiente FROM mensajes ORDER BY fecha DESC GROUP BY dependiente&quot;

Pero es que me da un error de sintaxis, la cuestión es que el GROUP BY lo tengo que poner después de que los ordene por fecha porque si no el orden no será el correcto. Una vez con esto creo que podré continuar.

¿Cómo ejecuto la consulta de arriba correctamente?

Ya sé que me devolverá el orden del id (por fecha) de los mensajes y las respuestas, y creo que eso me vale.

Un saludo :)

______________
¿Piensas que el software puede ser algo mas?
<a href="http://www.zonasiete.org/" target="_blank">www.zonasiete.org</a>
Acercando el proyecto GNU/Linux a todos.
  #7 (permalink)  
Antiguo 01/02/2002, 20:44
 
Fecha de Ingreso: enero-2002
Ubicación: Dentro del corralón
Mensajes: 287
Antigüedad: 15 años, 11 meses
Puntos: 0
Re: Consultas relacionadas. Ayuda por favor.

lical:
No tiene nada que ver el orden con el group by ya que uno lo estás haciendo sobre el campo dependiente y otro sobre el campo fecha. Lo que hace el group by es agruparte similares resultados. No podés cambiar la sintaxis del SQL. DEBE ser primero el GROUP BY y después el ORDER BY. Si querés date una vuelta por <a href='ir.asp?http://www.devshed.com/Server_Side/Administration/TalkToMe/page1.html' target='_blank'>http://www.devshed.com/Server_Side/Admin...</a> y fijate un lindo tutorial que dá un ejemplo de como manejar lo que necesitás vos usando una lista desordenada (el tag &lt;ul&gt; de html) e indentando según sea respuesta o respuesta de respuesta. Me pareció muy piola el modo en que lo maneja. Te lo recomiendo.
Suerte.

Leonardo D'Angelo
Buenos Aires
Argentina
  #8 (permalink)  
Antiguo 02/02/2002, 10:30
Avatar de lical
Colaborador
 
Fecha de Ingreso: diciembre-2001
Ubicación: $PWD
Mensajes: 1.267
Antigüedad: 16 años
Puntos: 0
Re: Consultas relacionadas. Ayuda por favor.

Me lo temía. Muchas gracias, lo miraré.

Un saludo.

______________
¿Piensas que el software puede ser algo mas?
<a href="http://www.zonasiete.org/" target="_blank">www.zonasiete.org</a>
Acercando el proyecto GNU/Linux a todos.
  #9 (permalink)  
Antiguo 04/02/2002, 10:56
Avatar de Webstudio
Colaborador
 
Fecha de Ingreso: noviembre-2001
Ubicación: 127.0.0.1
Mensajes: 3.499
Antigüedad: 16 años, 1 mes
Puntos: 68
Re: Consultas relacionadas. Ayuda por favor.

Lical, la única solución sencilla que se me ha ocurrido, es que le agregues 1 campo a la tabla, que se llame ultimo_post o algo asi.
Cada vez que se inserta un nuevo comentario en la base, deberás actualizar el registro del mensaje con id=dependiente, y actualizar esa fecha de ultimo_post.
De esa manera, te asegurarás una buena y veloz manera de ordenar los mensajes originadores de discusiones, por fecha de ultimo post.

Saludos.

<hr><font size=2 face="verdana">- Pablo Daniel Rigazzi (Webstudio)
<font size=1 color="#333333">COORDINADOR PROYECTO REGIONALIZACION ARGENTINA
Visita <a href="http://www.web-studio.com.ar" target="_blank">Web Studio</a> - Tutoriales Photoshop</fo
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 02:57.