IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Développement SQL Server Discussion :

indiqué la direction ASC ou DESC en paramètre procédure stockée


Sujet :

Développement SQL Server

  1. #1
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut indiqué la direction ASC ou DESC en paramètre procédure stockée
    Bonjour

    Je souhaiterais passer en paramètre d'une procédure stockée l'ordre de tri ...

    j'ai essayé avec un case mais sans succès ou même en mettant directement le paramètre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    select * from matable 
    order by CASE @ORDERBY
    		WHEN 'numero_rapport' THEN numero_rapport
    		WHEN 'type_rapport_id' THEN type_rapport_id
    		WHEN 'date_creation' THEN date_creation
    		WHEN 'statut' THEN statut
      ELSE date_creation
      END
    mais pour ASC et DESC ??

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 870
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 870
    Points : 53 033
    Points
    53 033
    Billets dans le blog
    6
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    SELECT *
    FROM   matable 
    ORDER BY CASE 
                WHEN @ORDERBY = 'numero_rapport' AND @SENS = 'croissant' THEN numero_rapport 
                WHEN 'type_rapport_id'           AND @SENS = 'croissant' THEN type_rapport_id
                WHEN 'date_creation'             AND @SENS = 'croissant' THEN date_creation
                WHEN 'statut'                    AND @SENS = 'croissant' THEN statut
    		    ELSE NULL
    		 END ASC,
    		 CASE 
                WHEN @ORDERBY = 'numero_rapport' AND @SENS = 'décroissant' THEN numero_rapport 
                WHEN 'type_rapport_id'           AND @SENS = 'décroissant' THEN type_rapport_id
                WHEN 'date_creation'             AND @SENS = 'décroissant' THEN date_creation
                WHEN 'statut'                    AND @SENS = 'décroissant' THEN statut
    		    ELSE NULL
    		 END DESC
    A +

  3. #3
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    Merci , c'est parfait

  4. #4
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Points : 1 234
    Points
    1 234
    Par défaut
    Si tu peux convertir chaque valeur à ordonner en entier, y a plus compact (en pseudocode) :

    order by valeur * (1|-1) ASC

  5. #5
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Points : 13 314
    Points
    13 314
    Par défaut
    Citation Envoyé par Sergejack Voir le message
    Si tu peux convertir chaque valeur à ordonner en entier, y a plus compact (en pseudocode) :

    order by valeur * (1|-1) ASC
    Ce qui a pour effet de faire faire un calcul au lieu d'utiliser les index éventuellements existants. Je ne vois pas bien le bénéfice ici.

  6. #6
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Points : 1 234
    Points
    1 234
    Par défaut
    Citation Envoyé par Bluedeep Voir le message
    Ce qui a pour effet de faire faire un calcul au lieu d'utiliser les index éventuellements existants. Je ne vois pas bien le bénéfice ici.
    Bien vu, j"ai gaffé ^^

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 6
    Dernier message: 04/12/2012, 16h42
  2. Echappement dans paramètres Procédure stockée
    Par Sanceray3 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 14/09/2009, 18h26
  3. paramètre procédure stockée
    Par joe.lindien dans le forum Requêtes et SQL.
    Réponses: 19
    Dernier message: 20/04/2007, 12h43
  4. [newbie]comment faire un mouseon/mouseover qui tri par ASC ou DESC?
    Par megapacman dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 30/06/2006, 13h01
  5. [SQLSERVER]Pb passage paramètre procédure stockée
    Par galinijay dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 01/08/2005, 11h59

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo