Classificando resultados de acordo com a ordem da cláusula WHERE IN
Ao usar a cláusula WHERE IN no SQL, os resultados normalmente são ordenados pela coluna natural ordenação (geralmente crescente). No entanto, em determinados cenários, você pode preferir que as linhas sejam retornadas na mesma ordem especificada na cláusula IN.
Solução: ordenação por campo
Para classificar linhas de acordo com a ordem especificada na cláusula WHERE IN, você pode usar a função ORDER BY FIELD. Esta função recebe dois argumentos:
Neste caso, você pode usar a seguinte consulta para classificar os resultados pela coluna ID, na ordem especificada na cláusula IN:
SELECT *
FROM table
WHERE id IN (118, 17, 113, 23, 72)
ORDER BY FIELD(id, 118, 17, 113, 23, 72);
Esta consulta retornará as linhas na seguinte ordem: 118, 17, 113, 23, 72.
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3