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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 7, 20262026-06-07T22:42:03+00:00 2026-06-07T22:42:03+00:00

I am working on an ASP.NET MVC project. The data access in through a

  • 0

I am working on an ASP.NET MVC project. The data access in through a repository that has a simple caching functionality. It contains several functions like the follwing two:

Public Function SelectAllCurrencies() As List(Of store_Currency) 
    Dim AllCurrencies As List(Of store_Currency)
    If UseCaching Then
        AllCurrencies = HttpContext.Current.Cache("AllCurrencies")
        If AllCurrencies Is Nothing Then
            AllCurrencies = (From Currencies In db.Currencies Order By Currencies.Title Ascending).ToList
            Cache.AddToCache("AllCurrencies", AllCurrencies)
        End If
    Else
        AllCurrencies = (From Currencies In db.Currencies Order By Currencies.Title Ascending).ToList
    End If
    Return AllCurrencies
End Function

Public Function SelectAllCountries() As List(Of store_Country) 
    Dim AllCountries As List(Of store_Country)
    If UseCaching Then
        AllCountries = HttpContext.Current.Cache("AllCountries")
        If AllCountries Is Nothing Then
            AllCountries = (From Countries In db.Countries Order By Countries.Title Ascending).ToList
            Cache.AddToCache("AllCountries", AllCountries)
        End If
    Else
        AllCountries = (From Countries In db.Countries Order By Countries.Title Ascending).ToList
    End If
    Return AllCountries
End Function

As you can see, they use the same workflow, over and over again. I want to remove this redundancy. I think that generics should provide a solution, but I can’t for the life of me figure out how to deal with the LINQ statements in a generic SelectAllEntities(Of T) function. Is there a way to ‘generalize’ the queries, maybe with dynamic LINQ?

  • 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-07T22:42:04+00:00Added an answer on June 7, 2026 at 10:42 pm

    My VB is a little rusty but I think you want to write your function like this.

    Public SelectAll(Of T, TOrder)(
            IEnumerable(Of T) source,
            Func(Of T, TOrder) keySelector,
            cacheKey As String = Nothing) As IList(Of T)
    
        Dim all As List(Of T)
        If me.UseCaching Then
            all = HttpContext.Current.Cache(cacheKey)
            If all Is Nothing Then
                all = source.OrderBy(keySelector).ToList()
                Cache.AddToCache(cacheKey, all)
            End If
        Else
            all = source.OrderBy(keySelector).ToList()
        End If
        Return all
    End Function
    

    Which you could use like this

    Dim allCountries = SelectAll(db.Countries, Function(c) c.Title, "AllCountries")
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have an ASP.NET MVC 2 project that I'm working on and I'm wondering
I need to make a simple asp.net MVC project, which contains a GridView. I
I've been working on a ASP.NET MVC project with LinqToSql. The application has 3
background:Me and my coworkers are working on asp.net mvc project ... we have a
I'm working on an ASP.NET MVC project which uses the MarkdownDeep Editor to add
I am currently working on an ASP.NET MVC project. Some developers on the team
I working on my first ASP.net MVC project and and i got some problems
I'm working with an ASP.NET MVC 2 project using a classic ASP.NET WebForm wired
I've integrated ASP.NET MVC 3 project into existing Web Forms project. It was working
I'm working on an ASP.NET MVC 2 / .NET 3.5 project which includes SSRS

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.