16
Oct
08

Manteniendo el orden de resultados SQL según un ‘in’

Si queremos obtener resultados ordenados con una query SQL y la condición del where es un IN, tenemos un problema. Pongamos que tenemos una query como la siguiente:

mysql> select * from category where status in (‘inactive’, ‘active’, ‘mutant’);

Con esto pretendemos obtener todos los campos de todas las filas de category, estando éstas agrupadas y ordenadas en el mismo orden en el que las hemos puesto en el IN. Si añadimos un GROUP BY nos aseguramos de que se agrupan, pero no de que se respete el orden que hemos puesto en la condición.

El orden del resultado será indeterminado (yo pensaba que iba a ser por id en un principio, pero no). La cosa tenía pinta de que íbamos a tener que realizar la ordenación a posteriori en la aplicación, aunque ha resultado ser que no. En MySQL podemos hacer lo siguiente:

mysql> select * from category where status in (‘inactive’, ‘active’, ‘mutant’) order by field(status,’inactive’, ‘active’, ‘mutant’) ;

Que funciona gracias a la función field de MySQL. Y problema resuelto.

Anuncios

1 Response to “Manteniendo el orden de resultados SQL según un ‘in’”


  1. 11 agosto 2014 en 2:17 am

    I pay a visit every day some web pages and sites to read articles
    or reviews, except this weblog offers quality based posts.


Responder

Introduce tus datos o haz clic en un icono para iniciar sesión:

Logo de WordPress.com

Estás comentando usando tu cuenta de WordPress.com. Cerrar sesión / Cambiar )

Imagen de Twitter

Estás comentando usando tu cuenta de Twitter. Cerrar sesión / Cambiar )

Foto de Facebook

Estás comentando usando tu cuenta de Facebook. Cerrar sesión / Cambiar )

Google+ photo

Estás comentando usando tu cuenta de Google+. Cerrar sesión / Cambiar )

Conectando a %s


A %d blogueros les gusta esto: