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 8830467
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 14, 20262026-06-14T08:05:46+00:00 2026-06-14T08:05:46+00:00

Is there any way to modify the following UPDATE statement so that the scalar

  • 0

Is there any way to modify the following UPDATE statement so that the scalar function is called only once, not twice?

UPDATE a
    SET SomeField = b.SomeField
    FROM TableA AS a
    JOIN TableB b ON b.Link = a.Link
    WHERE b.CostMin <= @Cost * dbo.OneScalarFunction(@CurrencyFrom, b.Currency)
        AND b.CostMax >= @Cost * dbo.OneScalarFunction(@CurrencyFrom, b.Currency)

P.S. Using the BETWEEN operator does not help – SQL Server calls the scalar function twice anyway.

  • 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-06-14T08:05:48+00:00Added an answer on June 14, 2026 at 8:05 am

    This is often significantly more performant, but requires you to change the scalar function to an inline table valued function.

    UPDATE
      a
    SET
      SomeField = b.SomeField
    FROM
      TableA AS a
    CROSS APPLY
      dbo.oneInlineTableValuedFunction(@CurrencyFrom, e.Currency) AS ITVF
    INNER JOIN
      TableB b
        ON b.Link = a.Link
    WHERE
          b.CostMin <= @Cost * ITVF.exchangeRate
      AND b.CostMax >= @Cost * ITVF.exchangeRate
    

    Although table valued functions return tables, you can choose to retun just one row with one field. Then you’re using it effectively as a scalar function – But, you get all the benefits of how SQL Server can optimise the query above…
    – If the TVF is Inline (and not multi-statement)
    – The TVF gets expanded out into the query
    – The result is performance dramatiaclly better than scalar functions

    Example Inline Table Valued Function:

    CREATE FUNCTION dbo.oneInlineTableValuedFunction (
                          @currencyFrom   VARCHAR(32),
                          @currencyTo     VARCHAR(32)
    )
    RETURNS TABLE
    AS
    RETURN (
      SELECT
        exchangeRate
      FROM
        dbo.someTable
      WHERE
            currencyFrom = @currencyFrom
        AND currencyTo   = @currencyTo
    )
    

    Deliberately trivial

    One example post about this: scalar-functions-inlining-and-performance

    If you seach the web for INLINE CROSS APPLY SCALAR FUNCTION PERFORMANCE I’m sure you’ll get a whole lot more.

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

Sidebar

Related Questions

In git, is there any (simple) way to modify the index so that only
Is there any way to modify the CSS properties of one table's cells based
Is there any way I can set a formatter on models that will convert
Is there any way to update nested documents by id or some other field?
is there any way to do the following. so i have a project.jar file,
Is there any way to modify central repository's configuration to disallow any remote pushing
Is there any way that I can link a keyword in a TextView to
Is there any way in Notepad++ (or even with another tool) to change the
Is there any way to use Google's API to retrieve a user's current zipcode
Is there any way to overload the > (greater than) operator, to be able

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.