Foros del Web » Programando para Internet » PHP »

Problema ordenar consulta mysql

Estas en el tema de Problema ordenar consulta mysql en el foro de PHP en Foros del Web. Hola! Tengo un problema, quiero ordenar datos de una cosulta pero que solo me ordene la tabla que yo quiero y no todas las tablas ...
  #1 (permalink)  
Antiguo 07/01/2011, 08:54
Avatar de galitcin  
Fecha de Ingreso: septiembre-2010
Ubicación: Barcelona
Mensajes: 30
Antigüedad: 13 años, 7 meses
Puntos: 0
Problema ordenar consulta mysql

Hola! Tengo un problema, quiero ordenar datos de una cosulta pero que solo me ordene la tabla que yo quiero y no todas las tablas ( ya que le pongo order by y me ordena todos los datos y no la dicha tabla)

mi consulta a la DB es :

Código PHP:
Ver original
  1. $sql = "SELECT a.*, UNIX_TIMESTAMP(a.createdon) AS timestamp, ct.cityname,
  2.                 COUNT(*) AS piccount, p.picfile,
  3.                 scat.$subcat_lang, cat.catid, cat.$cat_lang $xfieldsql
  4.             FROM $t_ads a
  5.                 INNER JOIN $t_cities ct ON a.cityid = ct.cityid
  6.                 INNER JOIN $t_subcats scat ON a.subcatid = scat.subcatid
  7.                 INNER JOIN $t_cats cat ON scat.catid = cat.catid
  8.                 LEFT OUTER JOIN $t_adxfields axf ON a.adid = axf.adid
  9.                 LEFT OUTER JOIN $t_adpics p ON a.adid = p.adid AND p.isevent = '0'
  10.                 LEFT OUTER JOIN $t_featured feat ON a.adid = feat.adid AND feat.adtype = 'A'
  11.             WHERE $where
  12.                 AND $visibility_condn
  13.                 AND (feat.adid IS NULL OR feat.featuredtill < NOW())
  14.                 $loc_condn
  15.             GROUP BY a.adid
  16.             ORDER BY a.createdon DESC          
  17.             LIMIT $offset, $ads_per_page";
  18.     $res = mysql_query($sql) or die($sql.mysql_error());


y la consulta la muestro asi:

Código PHP:
Ver original
  1. while($row=mysql_fetch_array($res))
  2.     {
  3.  
  4. // y despues quiero que me muestre la foto
  5.  
  6. <img src="<?php echo "$datadir[adthumbpics]/$row[picfile]"; ?>" border="0" width="90" height="70">

me muestra la imagen sin ningun problema... pero me muestra la ultima que el usuario ha cargado y no la primera,

en la consulta intente poner el ORDER BY pero me ordena todos los datos y no solo la tabla de las fotos...

Aver si me pueden ayudar....
  #2 (permalink)  
Antiguo 07/01/2011, 10:29
Avatar de ArkangelGammar  
Fecha de Ingreso: enero-2011
Ubicación: <?php $persona->ubicacion('ArkangelGammar'); ?>
Mensajes: 179
Antigüedad: 13 años, 4 meses
Puntos: 19
Respuesta: Problema ordenar consulta mysql

Si queres mostrar solo datos de una tabla, no tenes que poner

Código:
"SELECT a.*"
Ya ue te trae todos los campos.

Tenes que hacer un

Código:
select a.<nombre_de_campo>,a.<nombre_campos_2>
, etc


Espero haber ayudado.

Saludos
  #3 (permalink)  
Antiguo 07/01/2011, 10:48
Avatar de Nano_  
Fecha de Ingreso: febrero-2006
Ubicación: Bogotá, Colombia
Mensajes: 1.866
Antigüedad: 18 años, 2 meses
Puntos: 96
Respuesta: Problema ordenar consulta mysql

Saludos

Es por que no es
Código MySQL:
Ver original
  1. //Ordena Descendentemente es decir mostrara en tu caso la ultima foto que cargo
  2. ORDER BY a.createdon DESC        
  3. //Ordena Ascendentemente es decir mostrara en tu caso la primera foto que cargo
  4. //CORREGIDO
  5. ORDER BY a.createdon ASC
__________________
:.:Nano.:: @nano_hard - Retornando al foro
  #4 (permalink)  
Antiguo 07/01/2011, 11:32
Avatar de Ribon  
Fecha de Ingreso: septiembre-2010
Ubicación: El firmamento
Mensajes: 487
Antigüedad: 13 años, 7 meses
Puntos: 91
Respuesta: Problema ordenar consulta mysql

Lo que pasa es que al inicio pusiste

Código MySQL:
Ver original 

y el order by lo pusiste

Código MySQL:
Ver original
  1. ORDER BY a.createdon DESC

cuando debia ser


por el alias
  #5 (permalink)  
Antiguo 10/01/2011, 10:00
Avatar de galitcin  
Fecha de Ingreso: septiembre-2010
Ubicación: Barcelona
Mensajes: 30
Antigüedad: 13 años, 7 meses
Puntos: 0
Respuesta: Problema ordenar consulta mysql

Cita:
Iniciado por Ribon Ver Mensaje
Lo que pasa es que al inicio pusiste

Código MySQL:
Ver original 

y el order by lo pusiste

Código MySQL:
Ver original
  1. ORDER BY a.createdon DESC

cuando debia ser


por el alias
No mira, el a.createdon, se refiere al anuncio que ha sido creado por ultimo y en la consulta lo ordena por el ultimo publicado, que hasta ahi esta bien, pero junto al anuncio hice que me traiga tambien los datos de la tabla dnd esta la ruta de las fotos, el problema esta que el usuario puede cargar mas de una foto, y al traer el anuncio me muestra la ultima foto cargada por el usuario y no la primera, ahi es dnd tengo el problema, pero si pongo asi:

ORDER BY a.createdon, picid DESC ( o sea que ordene tambien por picid, me lo pondra en orden segun los ids de las fotos, la consulta, lo cual esta mal,

y por eso quiero que solo me ordene el resultado aparte de todos los datos que me trae....

no se si me explico?

Etiquetas: mysql
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 03:29.