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

  • Home
  • SEARCH
  • 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 315223
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 12, 20262026-05-12T08:16:18+00:00 2026-05-12T08:16:18+00:00

I have an expensive scalar UDF that I need to include in a select

  • 0

I have an expensive scalar UDF that I need to include in a select statement and use that value to narrow the results in the where clause. The UDF takes parameters from the current row so I can’t just store it in a var and select from that.

Running the UDF twice per row just feels wrong:

Select someField, 
       someOtherField, 
       dbo.MyExpensiveScalarUDF(someField, someOtherField)
from someTable
where dbo.MyExpensiveScalarUDF(someField, someOtherField) in (aHandfulOfValues)

How do I clean this up so that the function only runs once per row?

  • 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. Editorial Team
    Editorial Team
    2026-05-12T08:16:19+00:00Added an answer on May 12, 2026 at 8:16 am

    Just because you happen to mention the function twice doesn’t mean it will be computed twice per row. With luck, the query optimizer will computed it only once per row. Whether it does or not may depend in part on whether the UDF appears to be deterministic or nondeterministic.

    Take a look at the estimated execution plan. Maybe you’ll find out you’re worrying about nothing.

    If it’s computed twice, you could try this and see if it changes the plan, but it’s still no guarantee:

    WITH T(someField,someOtherField,expensiveResult) as (
      select someField, someOtherField, dbo.MyExpensiveScalarUDF(someField, someOtherField)
      from someTable
    )
      select * from T
      where expensiveResult in (thisVal,thatVal,theotherVal);
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a table that looks something like this: word big expensive smart fast
Say I have a Stream that's rather expensive to compute. I can easily create
I have a fairly expensive array calculation (SpectralResponse) which I like to keep to
I have a dataset in MySQL where using limit is already an expensive query,
I have a class in which looking up an instance is expensive, so instances
Source RegexOptions.IgnoreCase is more expensive than I would have thought (eg, should be barely
I'm wondering, how expensive it is to have many threads in waiting state in
Generally the database server is the biggest, most expensive box we have to buy
In general, how expensive is locking in Java? Specifically in my case: I have
In postgis, is the ST_GeomFromText call very expensive? I ask mostly because I have

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.