Je renvoie les résultats de la requête suivante qui prend trop de temps lors de l'exécution. Je ne suis pas sûr de savoir comment éliminer les paramètres where lorsqu'ils ne sont pas utilisés dans SSRS. Tous les @variables sont des chaînesVitesse SQL champs facultatifs SSRS
select S.SBSB_ID, LTRIM(RTRIM(M.MEME_FIRST_NAME)) + ' ' +
LTRIM(RTRIM(M.MEME_LAST_NAME)) AS Names,
(CASE M.MEME_REL WHEN 'M' THEN 'Subscriber'
WHEN 'S' THEN 'Son'
WHEN 'D' THEN 'Daughter'
WHEN 'W' THEN 'Wife'
WHEN 'H' THEN 'Husband'
WHEN 'O' THEN 'Other'
ELSE M.MEME_REL END) AS Relation,
(CASE A.PRPR_ID WHEN 'NONASSIGNED' THEN A.CLCL_PA_ACCT_NO
ELSE LTRIM(P.PRPR_NAME) END) AS ProvName,
LTRIM(RTRIM(L.CDDL_CUR_STS)) AS Status
FROM CMC_SBSB_SUBSC S INNER JOIN CMC_MEME_MEMBER M
ON S.SBSB_CK = M.SBSB_CK INNER JOIN CMC_CDDL_CL_LINE L
ON L.MEME_CK = M.MEME_CK INNER JOIN CMC_PRPR_PROV P
ON P.PRPR_ID = L.PRPR_ID INNER JOIN CMC_CLCL_CLAIM A
ON A.CLCL_ID = L.CLCL_ID
WHERE
S.SBSB_ID LIKE (CASE @subscriberID
WHEN '' THEN '%' ELSE @subscriberID END) AND
M.MEME_REL IN (@Relation) AND
UPPER(M.MEME_FIRST_NAME) LIKE '%' +
UPPER(CASE @firstName WHEN '' THEN '%' ELSE @firstName END) + '%' AND
UPPER(M.MEME_LAST_NAME) LIKE '%' +
UPPER(CASE @lastName WHEN '' THEN '%' ELSE @lastName END) + '%' AND
(L.CGCG_ID IN (@Category) OR L.CGCG_ID = '') AND
(CASE WHEN (@Tooth) = '' THEN L.CDDL_TOOTH_BEG
WHEN ISNUMERIC(@Tooth) = 0 THEN UPPER(@Tooth)
WHEN LEN(@Tooth) = 1 THEN '0' + @Tooth
ELSE @Tooth END) >= L.CDDL_TOOTH_BEG AND
(CASE WHEN (@Tooth) = '' THEN L.CDDL_TOOTH_BEG
WHEN ISNUMERIC(@Tooth) = 0 THEN UPPER(@Tooth)
WHEN LEN(@Tooth) = 1 THEN '0' + @Tooth
ELSE @Tooth END) <= L.CDDL_TOOTH_END AND
S.SBSB_CK IN (select SBSB_CK FROM CMC_MEME_MEMBER
WHERE MEME_SSN LIKE (CASE @SSN WHEN '' THEN '%' ELSE @SSN END)) AND
M.MEME_BIRTH_DT LIKE (CASE WHEN @DOB IS NULL THEN '%' ELSE @DOB END)
UNION
select S.SBSB_ID, LTRIM(RTRIM(M.MEME_FIRST_NAME)) + ' ' +
LTRIM(RTRIM(M.MEME_LAST_NAME)) AS Names,
(CASE M.MEME_REL WHEN 'M' THEN 'Subscriber'
WHEN 'S' THEN 'Son'
WHEN 'D' THEN 'Daughter'
WHEN 'W' THEN 'Wife'
WHEN 'H' THEN 'Husband'
WHEN 'O' THEN 'Other'
ELSE M.MEME_REL END) AS Relation,
RTRIM(LTRIM(P.PRPR_NAME)) AS ProvName,
'Purged - ' + H.CLDH_STS AS Status
FROM CMC_SBSB_SUBSC S INNER JOIN CMC_MEME_MEMBER M
ON S.SBSB_CK = M.SBSB_CK
INNER JOIN CMC_CLDH_DEN_HIST H ON H.MEME_CK = M.MEME_CK
INNER JOIN CMC_PRPR_PROV P ON P.PRPR_ID = H.PRPR_ID
WHERE
S.SBSB_ID LIKE (CASE @subscriberID
WHEN '' THEN '%' ELSE @subscriberID END) AND
M.MEME_REL IN (@Relation) AND
UPPER(M.MEME_FIRST_NAME) LIKE '%' +
UPPER(CASE @firstName WHEN '' THEN '%' ELSE @firstName END) + '%' AND
UPPER(M.MEME_LAST_NAME) LIKE '%' +
UPPER(CASE @lastName WHEN '' THEN '%' ELSE @lastName END) + '%' AND
(H.CGCG_ID IN (@Category) OR H.CGCG_ID = '') AND
(CASE WHEN (@Tooth) = '' THEN H.CLDH_TOOTH_BEG
WHEN ISNUMERIC(@Tooth) = 0 THEN UPPER(@Tooth)
WHEN LEN(@Tooth) = 1 THEN '0' + @Tooth
ELSE @Tooth END) >= H.CLDH_TOOTH_BEG AND
(CASE WHEN (@Tooth) = '' THEN H.CLDH_TOOTH_BEG
WHEN ISNUMERIC(@Tooth) = 0 THEN UPPER(@Tooth)
WHEN LEN(@Tooth) = 1 THEN '0' + @Tooth
ELSE @Tooth END) <= H.CLDH_TOOTH_END AND
S.SBSB_CK IN (select SBSB_CK FROM CMC_MEME_MEMBER
WHERE MEME_SSN LIKE (CASE @SSN WHEN '' THEN '%' ELSE @SSN END)) AND
M.MEME_BIRTH_DT LIKE (CASE WHEN @DOB IS NULL THEN '%' ELSE @DOB END)
Je préférerais avoir la requête ne pas exécuter des champs vides avec « % », mais ne savais pas comment les éliminer sous condition de la requête.
J'ai eu une section de problème ci-dessus « S.SBSB_CK IN (sélectionnez SBSB_CK DE CMC_MEME_MEMBER OU COMME MEME_SSN (CAS @SSN QUAND « » puis « % » FIN SINON @SSN)) ET » dont je fixe en permettant un contrôle nul boîte et en utilisant les suggestions ci-dessous de vérification de null avec un OU et cela accéléré considérablement la requête pour tous les autres cas (si l'utilisateur doit faire la longue mauvaise recherche, ils peuvent encore sur SSN, mais au moins, il ne fait pas mal autre 99% des recherches effectuées). –