J'ai un petit problème au niveau d'une requete SQL.
Je dispose d'une table matable qui possède un champ id qui est structuré de la façon suivante :
- Une lettre 'G','C','E','D' concaténée à un numéro de série . Ex:'C10006','G16547','E456','D1648','G1986'
Ce que je veux faire c'est restituer ces champs id avec un ordre précis : je m'explique je veux les données commencant par G puis par C puis par E puis par D. Pour l'exemple que j'ai donné le résultat devrait être le suivant:
G16547
G1986
C10006
E456
D1648
J'arrive à obtenir le résultat avec cette requête:
select * from matable where id like 'G%' UNION ALL select * from matable where id like 'C%' UNION ALL select * from matable where id like 'E%' UNION ALL select * from matable where id like 'D%'
Cependant je voudrais bien voir s'il n'y a pas moyen de simplifier cette requête.
Merci d'avance pour votre aide

SELECT *
FROM 'ma_table'
ORDER BY FIELD (id, 'G%', 'C%', 'E%', 'D%')
et pour rappel:
Les paramètres passés à la fonction FIELD() sont : le nom du champ de type chaîne de caractère sur lequel effectuer le tri, puis les occurences de cette chaîne dans l'ordre de tri souhaité.
Merci beaucoup
Pour ceux que ca interesse et qui travaillent sur Oracle l'équivalent est order by case when
c'est avec amour du dev qu'on fait ça