Order by function
RésoluHerve_be Messages postés 1121 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
Soit une table SQL qui contient les colonnes X et Y.
Je peux les trier par X (croissant ou décroissant), Y ou les deux.
Est-il possible de trier sur base dune fonction de X et Y ?
par exemple Order by (X/Y)
Merci d'avance pour votre aide
Windows / Chrome 129.0.0.0
6 réponses
Le développement informatique est ponctué de tests, d'échecs puis réussite. Il faut regarder la doc et essayer différentes syntaxes quand il n'y a pas d'exemple qui corresponde directement à ce que l'on souhaite. En plus le select est sans risque, ce n'est pas une instruction destructrice comme insert ou delete pour lesquelles on sera plus précautionneux.
"je parcours la table ... array", tu utilises un langage de programmation pour ton accès BDD ? comme Python, ou php ? dans ce cas, il faut utiliser à coté une fenêtre sql en mode ligne de commande pour tester les instructions. Le faire dans le programme est plus délicat, surtout quand la programmation des erreurs n'est pas impeccable, tu ne récupères alors pas le message d'erreur en retour d'une instruction qui échoue.
bonjour,
c'est quoi cette fonction de X et Y?
qu'as-tu essayé?
quel résultat as-tu obtenu?
La fonction peut être n'importe quelle opération entre les colonnes X et Y, par exemple f=X/Y, f=X+Y, F=X*Y, ...
Je n'ai rien essayé parce que je ne sais pas comment l'exprimer dans un Select ni même si c'est possible.
Ce que je fais actuellement :
je parcours la table, pour chaque row je calcule la fonction et je met la valeur dans un array
je trie l'array
je me demandais si on ne peut pas obtenir le même résultat directement à partir du Select.
Bonjour,
Est-ce que select X, Y from table order by X/Y marche ? je ne sais pas, mais avant de poser la question tu as testé ? et quelle est la réponse ?
Moi si je teste et que cela ne fonctionne pas j'essaie select X, Y, X/Y as QUOT from table order by QUOT
Salut,
le plus simple est d'ajouter une colonne où tu feras ton calcul et ensuite trier sur celle-ci.
select a,b,(x/y) as "new" from table1 order by 3 asc
<edit> doublon avec la réponse de jee pee...
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre questionpeut-être ainsi?
SELECT `X`,`Y` FROM `TesTable` ORDER BY (`X`/(unix_timestamp()/86400-`Y`)) DESC