Ver Mensaje Individual
  #6 (permalink)  
Antiguo 05/02/2013, 09:35
jurena
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Cáceres
Mensajes: 3.735
Antigüedad: 16 años, 7 meses
Puntos: 300
Respuesta: Consulta a base de datos MYSQL-PHP condionada

perdona, no te puse bien el orden para lo que quieres. Puesto que los otros colores no importan, usa este orden
Código MySQL:
Ver original
  1. FROM tabla
  2. WHERE codigo != @codigo
  3. ORDER BY FIELD( `color` , 'rojo' ) DESC LIMIT 3
El problema es que al no indicar el orden de los otros colores, los otros colores pasan a ser nulos y el nulo se ordena antes que nada... De ahí que tengas que ordenar primero descendente, y luego, si quieres, puedes añadir otro orden.
Un único problema: saldrán datos, aunque no haya ningún rojo. Si debes evitar ese caso, primero tendrías que lanzar una consulta para comprobar que al menos hay un registro con color rojo.

Última edición por jurena; 05/02/2013 a las 10:43