CASE dans T-SQL
Résolu
soleil_levant
Messages postés
393
Date d'inscription
Statut
Membre
Dernière intervention
-
soleil_levant Messages postés 393 Date d'inscription Statut Membre Dernière intervention -
soleil_levant Messages postés 393 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
Je souhaite utiliser un SWITCh dans une requête SQL, on m'a dis que CASE est la solution, J'essaie de faire une sorte de sélection d'instruction WHERE selon la valeur de mon paramètre @Moth, mais ça ne marche pas et d'entrée mon Editeur de base me dis qu'il y un erreur dans l'opérateur IN, voici mon code :
(pr info) Le but est de basculer entre l'année en cour et l'année précédente pr sélectionner toujours les 4 mois glissant
....
IF @Month <> ''
AND @type_declaration LIKE '%REC%'
BEGIN
SELECT MTCN, Account, SendPayIndicator, PayDateLOCDay, PayDateLOCMonth, ..
WHERE T.SendPayIndicator = 'P'
AND
(
CASE @Month
WHEN 1 THEN T.PayDateLOCMonth IN(9, 10, 11, 12)
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1
WHEN 2 THEN ((T.PayDateLOCMonth IN(10, 11, 12)
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1)
OR (T.PayDateLOCMonth IN(1)
AND T.PayDateLOCYear = YEAR(GETDATE())))
WHEN 3 THEN ((T.PayDateLOCMonth IN(12, 11)
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1)
OR (T.T.PayDateLOCMonth IN(1, 2)
AND T.PayDateLOCYear = YEAR(GETDATE())))
WHEN 4 THEN ((T.PayDateLOCMonth IN(12)
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1)
OR (T.PayDateLOCMonth IN(1, 2, 3)
AND T.PayDateLOCYear = YEAR(GETDATE())))
ELSE ...
END
)
Quelqu'un a une idée s'il vous plaît??
Merci d'avance
Je souhaite utiliser un SWITCh dans une requête SQL, on m'a dis que CASE est la solution, J'essaie de faire une sorte de sélection d'instruction WHERE selon la valeur de mon paramètre @Moth, mais ça ne marche pas et d'entrée mon Editeur de base me dis qu'il y un erreur dans l'opérateur IN, voici mon code :
(pr info) Le but est de basculer entre l'année en cour et l'année précédente pr sélectionner toujours les 4 mois glissant
....
IF @Month <> ''
AND @type_declaration LIKE '%REC%'
BEGIN
SELECT MTCN, Account, SendPayIndicator, PayDateLOCDay, PayDateLOCMonth, ..
WHERE T.SendPayIndicator = 'P'
AND
(
CASE @Month
WHEN 1 THEN T.PayDateLOCMonth IN(9, 10, 11, 12)
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1
WHEN 2 THEN ((T.PayDateLOCMonth IN(10, 11, 12)
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1)
OR (T.PayDateLOCMonth IN(1)
AND T.PayDateLOCYear = YEAR(GETDATE())))
WHEN 3 THEN ((T.PayDateLOCMonth IN(12, 11)
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1)
OR (T.T.PayDateLOCMonth IN(1, 2)
AND T.PayDateLOCYear = YEAR(GETDATE())))
WHEN 4 THEN ((T.PayDateLOCMonth IN(12)
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1)
OR (T.PayDateLOCMonth IN(1, 2, 3)
AND T.PayDateLOCYear = YEAR(GETDATE())))
ELSE ...
END
)
Quelqu'un a une idée s'il vous plaît??
Merci d'avance
A voir également:
- CASE dans T-SQL
- Aller à la ligne dans une case excel - Guide
- Excel case choix multiple - Guide
- Logiciel sql - Télécharger - Bases de données
- Sql (+) - Forum Programmation
- Supprimer case à cocher excel ✓ - Forum Excel
4 réponses
Hello, tu peux m'expliquer de nouveau j'ai pas compris ce que tu veux faire.
Tu es sur que ton case est bien placé ? Je ne crois pas. Plutot dans le select non ?
S'il s'agit de switcher sur plusieurs mois différents c'est dans ton programme que tu le gère ça
Tu es sur que ton case est bien placé ? Je ne crois pas. Plutot dans le select non ?
S'il s'agit de switcher sur plusieurs mois différents c'est dans ton programme que tu le gère ça
Bonjour,
Effectivement, je veux switcher entre les mois et année, c'est clair que le Case est mal placé, c'est une idée de ma part alors elle s'avère pas correcte. Mais le but est la.
Le but est de sélectionner les donnée sur 4 mois glissant. Si mon paramètre vaut 5 (mois avril) je dois sélectionner tjrs le mois antérieure et les 3 mois qui précédent. Si mon paramètre mois vaut 4, je sélectionne pour le mois 3 (mars) et la je dois réculer et entrer dans l'année antérieure pr prendre aussi le mois de 12 (décembre) ... Il faut généraliser donc tous les cas de figure.
Avez vous une idée s'il vour plaît.
Merci infiniment
Effectivement, je veux switcher entre les mois et année, c'est clair que le Case est mal placé, c'est une idée de ma part alors elle s'avère pas correcte. Mais le but est la.
Le but est de sélectionner les donnée sur 4 mois glissant. Si mon paramètre vaut 5 (mois avril) je dois sélectionner tjrs le mois antérieure et les 3 mois qui précédent. Si mon paramètre mois vaut 4, je sélectionne pour le mois 3 (mars) et la je dois réculer et entrer dans l'année antérieure pr prendre aussi le mois de 12 (décembre) ... Il faut généraliser donc tous les cas de figure.
Avez vous une idée s'il vour plaît.
Merci infiniment
Bonjour soleil_levant,
Peut-être que le code suivant devrait faire ce que tu veux
J'ai testé ce code sur une table SQL SERVER , pas avec les mêmes variables mais cela fais (je pense) ce que tu veux. Cela suppose aussi que ton paramètre @Month est du type smallint
A plus
Peut-être que le code suivant devrait faire ce que tu veux
declare @Month1 smallint declare @Month2 smallint declare @Month3 smallint declare @Month4 smallint declare @Year1 smallint declare @Year2 smallint declare @Year3 smallint declare @Year4 smallint IF @Month <> '' AND @type_declaration LIKE '%REC%' BEGIN set @Month1 = @Month - 1 set @Year1 = YEAR(GETDATE()) If @Month1 = 0 BEGIN set @Month1 = 12 set @Year1 = @Year1 - 1 END set @Month2 = @Month1 - 1 set @Year2 = @Year1 If @Month2 = 0 BEGIN set @Month2 = 12 set @Year2 = @Year2 - 1 END set @Month3 = @Month2 - 1 set @Year3 = @Year2 If @Month3 = 0 BEGIN set @Month3 = 12 set @Year3 = @Year3 - 1 END set @Month4 = @Month3 - 1 set @Year4 = @Year3 If @Month4 = 0 BEGIN set @Month4 = 12 set @Year4 = @Year4 - 1 END SELECT MTCN, Account, SendPayIndicator, PayDateLOCDay, PayDateLOCMonth, .. WHERE T.SendPayIndicator = 'P' AND ((T.PayDateLocMonth = @Month1 AND T.PayDateLOCYear = @Year1) OR (T.PayDateLocMonth = @Month2 AND T.PayDateLOCYear = @Year2) OR (T.PayDateLocMonth = @Month3 AND T.PayDateLOCYear = @Year3) OR (T.PayDateLocMonth = @Month4 AND T.PayDateLOCYear = @Year4)) END
J'ai testé ce code sur une table SQL SERVER , pas avec les mêmes variables mais cela fais (je pense) ce que tu veux. Cela suppose aussi que ton paramètre @Month est du type smallint
A plus
Salut Christounet,
MErci à toi Christounet mon sauveur :)
En faite j'ai trouvé une solution depuis, elle ressemble à la tienne .. lol pas trop, la tienne beaucoup mieux.
Voici la mienne:
DECLARE @mois int, @type_declaration char(50)
SET @mois = 8 /* La j'affecte le mois manuellement, c'est le but en faite*/
SET @type_declaration = 'REC' /* le type de déclaration aussi */
IF @mois NOT IN(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12)
PRINT 'Saisir une Date comprise entre 1 et 12'
ELSE IF @mois = 1
BEGIN
SELECT MTCN, SendPayIndicator
FROM qryTransactionDetails T
WHERE T.SendPayIndicator = 'P'
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1
AND T.PayDateLOCMonth BETWEEN 9 AND 12
AND T.Adjustment_ID = '-1'
END
--ELSE
--PRINT 'Ca ne serre à rien'
ELSE IF @mois = 2
BEGIN
SELECT MTCN, SendPayIndicator
FROM qryTransactionDetails T
WHERE T.SendPayIndicator = 'P'
AND ((T.PayDateLOCYear = YEAR(GETDATE()) - 1
AND T.PayDateLOCMonth BETWEEN 10 AND 12 )
OR
(T.PayDateLOCYear = YEAR(GETDATE())
AND T.PayDateLOCMonth = 1))
AND T.Adjustment_ID = '-1'
END
ELSE IF @mois = 3
BEGIN
SELECT MTCN, SendPayIndicator
FROM qryTransactionDetails T
WHERE T.SendPayIndicator = 'P'
AND ((T.PayDateLOCYear = YEAR(GETDATE()) - 1
AND T.PayDateLOCMonth BETWEEN 11 AND 12)
OR
(T.PayDateLOCYear = YEAR(GETDATE())
AND T.PayDateLOCMonth BETWEEN 1 AND 2))
AND T.Adjustment_ID = '-1'
END
ELSE IF @mois = 4
BEGIN
SELECT MTCN, SendPayIndicator
FROM qryTransactionDetails T
WHERE T.SendPayIndicator = 'P'
AND ((T.PayDateLOCYear = YEAR(GETDATE()) - 1
AND T.PayDateLOCMonth = 12)
OR (T.PayDateLOCYear = YEAR(GETDATE())
AND T.PayDateLOCMonth BETWEEN 1 AND 3))
AND T.Adjustment_ID = '-1'
END
..manque le meme type pr le reste des mois.
GO
MErci Christounet,
MILLE MERCI!!
Je vais la tester demain, mais la syntaxe, l'ergonomie du code est bien meilleure!!
A+
MErci à toi Christounet mon sauveur :)
En faite j'ai trouvé une solution depuis, elle ressemble à la tienne .. lol pas trop, la tienne beaucoup mieux.
Voici la mienne:
DECLARE @mois int, @type_declaration char(50)
SET @mois = 8 /* La j'affecte le mois manuellement, c'est le but en faite*/
SET @type_declaration = 'REC' /* le type de déclaration aussi */
IF @mois NOT IN(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12)
PRINT 'Saisir une Date comprise entre 1 et 12'
ELSE IF @mois = 1
BEGIN
SELECT MTCN, SendPayIndicator
FROM qryTransactionDetails T
WHERE T.SendPayIndicator = 'P'
AND T.PayDateLOCYear = YEAR(GETDATE()) - 1
AND T.PayDateLOCMonth BETWEEN 9 AND 12
AND T.Adjustment_ID = '-1'
END
--ELSE
--PRINT 'Ca ne serre à rien'
ELSE IF @mois = 2
BEGIN
SELECT MTCN, SendPayIndicator
FROM qryTransactionDetails T
WHERE T.SendPayIndicator = 'P'
AND ((T.PayDateLOCYear = YEAR(GETDATE()) - 1
AND T.PayDateLOCMonth BETWEEN 10 AND 12 )
OR
(T.PayDateLOCYear = YEAR(GETDATE())
AND T.PayDateLOCMonth = 1))
AND T.Adjustment_ID = '-1'
END
ELSE IF @mois = 3
BEGIN
SELECT MTCN, SendPayIndicator
FROM qryTransactionDetails T
WHERE T.SendPayIndicator = 'P'
AND ((T.PayDateLOCYear = YEAR(GETDATE()) - 1
AND T.PayDateLOCMonth BETWEEN 11 AND 12)
OR
(T.PayDateLOCYear = YEAR(GETDATE())
AND T.PayDateLOCMonth BETWEEN 1 AND 2))
AND T.Adjustment_ID = '-1'
END
ELSE IF @mois = 4
BEGIN
SELECT MTCN, SendPayIndicator
FROM qryTransactionDetails T
WHERE T.SendPayIndicator = 'P'
AND ((T.PayDateLOCYear = YEAR(GETDATE()) - 1
AND T.PayDateLOCMonth = 12)
OR (T.PayDateLOCYear = YEAR(GETDATE())
AND T.PayDateLOCMonth BETWEEN 1 AND 3))
AND T.Adjustment_ID = '-1'
END
..manque le meme type pr le reste des mois.
GO
MErci Christounet,
MILLE MERCI!!
Je vais la tester demain, mais la syntaxe, l'ergonomie du code est bien meilleure!!
A+
ça serre à quoi de me poser des questions sur mon problème et vous enfuir après et plus me répondre :( c'est pas trop cool
a+