Je travaille avec une requête qui contient une déclaration "CASE" dans la clause "WHERE". Mais SQL Server 2008 renvoie des erreurs lors de son exécution. Est-ce que quelqu'un pourrait m'aider avec la requête correcte ? Voici la requête :
SELECT
tl.storenum 'Store #',
co.ccnum 'FuelFirst Card #',
co.dtentered 'Date Entered',
CASE st.reasonid
WHEN 1 THEN 'Actif'
WHEN 2 THEN 'Non actif'
WHEN 0 THEN st.ccstatustypename
ELSE 'Inconnu'
END 'Statut',
CASE st.ccstatustypename
WHEN 'Actif' THEN ' '
WHEN 'Non actif' THEN ' '
ELSE st.ccstatustypename
END 'Raison',
UPPER(REPLACE(REPLACE(co.personentered,'RT\\\\',''),'RACETRAC\\\\','')) 'Personne entrée',
co.comments 'Commentaires ou Notes'
FROM
comments co
INNER JOIN cards cc ON co.ccnum=cc.ccnum
INNER JOIN customerinfo ci ON cc.customerinfoid=ci.customerinfoid
INNER JOIN ccstatustype st ON st.ccstatustypeid=cc.ccstatustypeid
INNER JOIN customerstatus cs ON cs.customerstatuscd=ci.customerstatuscd
INNER JOIN transactionlog tl ON tl.transactionlogid=co.transactionlogid
LEFT JOIN stores s ON s.StoreNum = tl.StoreNum
WHERE
CASE LEN('TestPerson')
WHEN 0 THEN co.personentered = co.personentered
ELSE co.personentered LIKE '%TestPerson'
END
AND cc.ccnum = CASE LEN('TestFFNum')
WHEN 0 THEN cc.ccnum
ELSE 'TestFFNum'
END
AND CASE LEN('2011-01-09 11:56:29.327')
WHEN 0 THEN co.DTEntered = co.DTEntered
ELSE
CASE LEN('2012-01-09 11:56:29.327')
WHEN 0 THEN co.DTEntered >= '2011-01-09 11:56:29.327'
ELSE co.DTEntered BETWEEN '2011-01-09 11:56:29.327' AND '2012-01-09 11:56:29.327'
END
END
AND tl.storenum < 699
ORDER BY tl.StoreNum
2 votes
Cas d'expression, pas d'instruction... (La case d'expression renvoie une valeur. La case d'instruction est utilisée dans les procédures stockées pour l'exécution conditionnelle du code.)