Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 154261
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T09:56:51+00:00 2026-05-11T09:56:51+00:00

I have been using this method to filter my queries: Create PROCEDURE [dbo].[pGetTask] @showCompletedTasks

  • 0

I have been using this method to filter my queries:

Create PROCEDURE [dbo].[pGetTask]     @showCompletedTasks bit = 1     ,@showInProgressTasks bit = 1     ,@taskID int = null     ,@projectID int = null     ,@applicationID int = null     ,@clientID int = null  ... Snip ...  where            a.clientID = isnull(@clientID, a.clientID)     and a.applicationID = isnull(@applicationID, a.applicationID)     and p.projectID = isnull(@projectID, p.projectID)     and t.taskID = isnull(@taskID, t.taskID)     and curr.complete = case @showCompletedTasks when 0 then 0 else curr.complete end     and curr.complete = case @showInProgressTasks when 0 then 1 else curr.complete end 

This actually slows my queries by 2 seconds on a 664 row result set. The SQL tuning advisor isn’t much help, so I figure this is not the right way to do this. Is there a right way, besides a ton of if statements?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T09:56:52+00:00Added an answer on May 11, 2026 at 9:56 am

    Assuming you have properly indexed the table that the select is on, and these fields are part of the index, my guess is that it would be the calls to isnull. I would change them to this:

    (@clientID is null or a.clientID = @clientId) and ... 

    As for the case statements, indexes on bit fields are pointless, so there’s not much to do there.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 114k
  • Answers 114k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer The addons/extensions are stored under Linux in: $HOME/.mozilla/firefox/profile.default/extensions. The profile… May 11, 2026 at 10:17 pm
  • Editorial Team
    Editorial Team added an answer Why do you need that variable? The standard way of… May 11, 2026 at 10:17 pm
  • Editorial Team
    Editorial Team added an answer This works automagically if you order your parameters and datasets… May 11, 2026 at 10:17 pm

Related Questions

I'm finally starting out with unit testing, having known that I should be doing
Have been looking at the MVC storefront and see that IQueryable is returned from
I came across this recently, up until now I have been happily overriding the
I having trouble in dividing the HTML frames. I have been using the following

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.