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 :

Valeurs Multiples pour une variable


Sujet :

Développement SQL Server

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    148
    Détails du profil
    Informations personnelles :
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Septembre 2002
    Messages : 148
    Points : 70
    Points
    70
    Par défaut Valeurs Multiples pour une variable
    Bonjour,
    Voici mon probleme , j'essaye d'avoir le meme resultat en effectuant cette procedure :
    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    SELECT 
    	max(T1.Région) AS Region,
    	max(T1.Agence) AS Agence,
    	T1.Affaire,
     
    	case
    	when max(T4.[Statut Affaire]) = '2' Then 'Affaire Facturée'
    	when max(T4.[Statut Affaire]) = '3' Then 'Dossier Archivé '
    	end AS statut_affaires,
     
    	max(convert(char(10),T4.[Ending Date],103)) AS Date_Fin,	
    	max(T4.[Description]) AS Description,
    	max(T4.[Type mission]) AS mission,
    	max(T1.[Code Ingénieur])AS Ingenieur,
    	sum(cast((T1.[Phase A])AS float)) AS Montant_ A,
    	sum(cast((T1.[Phase B complet])AS float)) AS Montant_ B,
    	sum(cast((T1.[Phase C])AS float)) AS Montant_ C,
    	sum(cast((T1.[Phase D])AS float)) AS Montant_ D,
    	sum(cast((T1.[Phase A]+T1.[Phase C]+T1.[Phase D]+T1.[Phase B complet])AS float)) AS Montant,
    	max(T3.jours_Prod) AS jours_Prod,
    	cast((sum(T1.[Phase B complet]) / max(T3.jours_Prod)) AS decimal(18,2)) AS PTVE
     
    FROM dbo.[Societe$Statistiques] T1
    	LEFT OUTER JOIN dbo.[SOCIETE$Job] T4
    	ON T1.Affaire = T4.No_
     
    			OUTER apply (
    					SELECT 
    						sum(cast(T2.[Présence Réel Equipe] AS float)) AS jours_Prod
     
    					FROM dbo.[SOCIETE$Production Chantier] T2
     
    					WHERE T1.Affaire = T2.[Document No_]
    						AND T2.No_ = 'PR'
    						AND T2.[Présence Réel Equipe] <> '0'
    					) T3
     
    WHERE T1.[Date Facture] BETWEEN @debut AND @Fin
    	AND T1.[Région] = 'NORD'
    	AND T1.Agence IN (@Agence)
    	AND T4.[Ending Date] <> '01/01/1753'
    	AND T1.[Type Document] < '2'
    	AND T4.[Statut Affaire] BETWEEN '2' AND '3'
     
    GROUP BY T1.Affaire
    ORDER BY T1.Affaire
    que si j'essaye de faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AND T1.Agence IN ('Paris','Marseille')
    Cette procedure va apres etre utilisée dans un rapport

    MErci pour votre aide

  2. #2
    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
    Quel est votre problème ?
    Most Valued Pas mvp

  3. #3
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour

    Vous ne pouvez pas procéder ainsi, car @agence est considéré comme une valeur, votre requête va donc chercher les lignes pour lesquels
    agence = 'Paris, Marseille'

    votre requete serait interpretée comme
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    AND T1.agence IN ('Paris, Marseille')

    et non comme
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    AND T1.agence IN ('Paris', 'Marseille')


    D’où provient @agence ?

    vous pouvez passer par une variable table ou une variable XML

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    148
    Détails du profil
    Informations personnelles :
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Septembre 2002
    Messages : 148
    Points : 70
    Points
    70
    Par défaut
    Bonjour,
    Si j'utilise cette procedure :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AND T1.Agence IN (@Agence)
    Je n'arrive pas au meme resultat que ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    AND T1.Agence IN ('Paris','Marseille')
    Faut il respecter un format de saisie , ou peut on saisir au moment du choix de la variable ex : Paris,Marseille

  5. #5
    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 aieeeuuuuu Voir le message
    vous pouvez passer par une variable table ou une variable XML
    Si vous êtes en Sql Server 2008, une variable table ferait bien l'affaire.
    Sinon, vous pouvez utiliser des tables temporaires ou des query dynamiques mais dans votre cas, peut-être que faire une view serait plus intéressant.
    Most Valued Pas mvp

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    148
    Détails du profil
    Informations personnelles :
    Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Septembre 2002
    Messages : 148
    Points : 70
    Points
    70
    Par défaut
    MERCI pour votre aide , effectivement , ca confirme ce que je pensais.

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

Discussions similaires

  1. Acces multiple pour une variable
    Par titou31000 dans le forum Langage
    Réponses: 10
    Dernier message: 01/04/2011, 14h09
  2. valeurs multiples pour une même clé
    Par Stouille89 dans le forum jQuery
    Réponses: 13
    Dernier message: 27/08/2010, 20h10
  3. [MySQL] Plusieurs valeurs pour une variable à injecter
    Par pony99 dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 03/12/2008, 12h04
  4. Obtenir le nombre de valeurs non manquantes pour une variable
    Par marie mouse dans le forum SAS Base
    Réponses: 5
    Dernier message: 14/12/2007, 17h33
  5. 2 valeurs possibles pour une variable : méthode Seek
    Par Corinne4775 dans le forum Access
    Réponses: 8
    Dernier message: 12/02/2007, 19h00

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