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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 12, 20262026-06-12T13:59:03+00:00 2026-06-12T13:59:03+00:00

I had the following code query = query.Where(device => GetDeviceDistanceFromGeocode(geocode, device) <= distanceMetres); private

  • 0

I had the following code

query = query.Where(device => GetDeviceDistanceFromGeocode(geocode, device) <= distanceMetres);

private static double GetDeviceDistanceFromGeocode(Geocode geocode, Device device)
{
    return Math.Pow(
        Math.Pow(device.Address.Geocode.Easting - geocode.Easting, 2) +
        Math.Pow(device.Address.Geocode.Northing - geocode.Northing, 2)
        , 0.5);
}

However it throws an exception because linq cannot recognise my function forcing me into doing the whole query expression in one go.

Exception[LINQ to Entities does not recognize the method 
'Double DistanceOfDeviceFromGeocode(Geocode, Device)' method, 
and this method cannot be translated into a store expression.] 

Is it possible to break a query expression out into multiple parts like i’m trying to do here? It’s not very readable when the query is so big.


EDIT:

Here’s the full query as asked for in the comments.

return query.Where(device => 
            Math.Pow(
                Math.Pow(device.Address.Geocode.Easting - geocode.Easting, 2) + 
                Math.Pow(device.Address.Geocode.Northing - geocode.Northing, 2)
                , 0.5) 
                <= distanceMetres);

Basically I don’t think this is very readable so would like to break it down into multiple parts but from the links supplied it doesn’t seem possible.

In c++ I could have broken some of it out into a macro but unfortunately this isn’t a feature of c#.


Following suggestions I’ve updated the code to this which works quite nicely and improves the readability of the code a lot!

    return query.Where( DevicesWithinDistanceFromGeocode(distanceMetres, geocode) );
}

public Expression<Func<Device, bool>> DevicesWithinDistanceFromGeocode(double distance, Geocode geocode)
{
    return device => (  SqlFunctions.SquareRoot(
                            SqlFunctions.Square((double)(device.Address.Geocode.Easting - geocode.Easting)) +
                            SqlFunctions.Square((double)(device.Address.Geocode.Northing - geocode.Northing))
                        ) <= distance );
}
  • 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-12T13:59:04+00:00Added an answer on June 12, 2026 at 1:59 pm

    Technically there are ways to do it, however since Linq can’t directly translate your custom code to SQL they require returning ALL results to Linq and then evaluating the custom methods.

    Since you’re using this in a Where clause I’m assuming that you expect to retrieve a relatively small number of records. In that case I would recommend coding your condition in SQL, either in a stored procedure or scalar-valued function, then using that sproc/function in your Linq-to-Entities query.

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

Sidebar

Related Questions

I initially had the following code: Boolean successCheckPoint = false; Boolean failureCheckPoint = false;
Recently I attended a lecture concerning some design patterns: The following code had been
Somewhere here on Stack Overflow, I had found the following code some day which
I had no problem at all running the following code on a local server,
I have the following code setup: http://jsfiddle.net/bABHU/2/ Had to change it a little bit
I've been using the following code to move views around, and never had a
If I had to following file on my development branch: # file.rb class Code
I had the following query that doesn't work and I was wondering how to
I am using the following code to query posts for categories: <?php query_posts(cat=8); ?>
I had the following Linq code: var allRequests = model.GetAllRequests(); var unsatisifedRequests = (from

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.