Précédent   Forum des professionnels en informatique > Bases de données > MS SQL-Server > Développement
Développement Forum d'entraide sur le Transact-SQL, le CLR, les procédures stockées, les triggers, les requêtes SQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 07/06/2011, 15h03   #1
Nouveau Membre du Club
 
Inscription : septembre 2002
Messages : 138
Détails du profil
Informations personnelles :
Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : septembre 2002
Messages : 138
Points : 38
Points : 38
Par défaut Valeurs Multiples pour une variable

Bonjour,
Voici mon probleme , j'essaye d'avoir le meme resultat en effectuant cette procedure :
Code :
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 :
AND T1.Agence IN ('Paris','Marseille')
Cette procedure va apres etre utilisée dans un rapport

MErci pour votre aide
backdraf est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/06/2011, 15h42   #2
Membre chevronné
 
Inscription : juillet 2006
Messages : 1 194
Détails du profil
Informations forums :
Inscription : juillet 2006
Messages : 1 194
Points : 746
Points : 746
Quel est votre problème ?
Sergejack est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/06/2011, 15h55   #3
Membre Expert
 
Inscription : janvier 2010
Messages : 1 084
Détails du profil
Informations personnelles :
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : janvier 2010
Messages : 1 084
Points : 1 573
Points : 1 573
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 :
1
2
 
AND T1.agence IN ('Paris, Marseille')

et non comme
Code SQL :
1
2
 
AND T1.agence IN ('Paris', 'Marseille')


D’où provient @agence ?

vous pouvez passer par une variable table ou une variable XML
aieeeuuuuu est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/06/2011, 15h58   #4
Nouveau Membre du Club
 
Inscription : septembre 2002
Messages : 138
Détails du profil
Informations personnelles :
Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : septembre 2002
Messages : 138
Points : 38
Points : 38
Bonjour,
Si j'utilise cette procedure :
Code :
AND T1.Agence IN (@Agence)
Je n'arrive pas au meme resultat que ca :
Code :
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
backdraf est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/06/2011, 16h07   #5
Membre chevronné
 
Inscription : juillet 2006
Messages : 1 194
Détails du profil
Informations forums :
Inscription : juillet 2006
Messages : 1 194
Points : 746
Points : 746
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.
Sergejack est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/06/2011, 16h34   #6
Nouveau Membre du Club
 
Inscription : septembre 2002
Messages : 138
Détails du profil
Informations personnelles :
Localisation : France, Vaucluse (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : septembre 2002
Messages : 138
Points : 38
Points : 38
MERCI pour votre aide , effectivement , ca confirme ce que je pensais.
backdraf est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 20h35.


 
 
 
 
Partenaires

Hébergement Web