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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 28, 20262026-05-28T13:38:06+00:00 2026-05-28T13:38:06+00:00

I have a website that allows users to query for specific recipes using various

  • 0

I have a website that allows users to query for specific recipes using various search criteria. For example, you can say “Show me all recipes that I can make in under 30 minutes that will use chicken, garlic and pasta but not olive oil.”

This query is sent to the web server over JSON, and deserialized into a SearchQuery object (which has various properties, arrays, etc).

The actual database query itself is fairly expensive, and there’s a lot of default search templates that would be used quite frequently. For this reason, I’d like to start caching common queries. I’ve done a little investigation into various caching technologies and read plenty of other SO posts on the subject, but I’m still looking for advice on which way to go. Right now, I’m considering the following options:

  1. Built in System.Web.Caching: This would provide a lot of control over how many items are in the cache, when they expire, and their priority. However, cached objects are keyed by a string, rather than a hashable object. Not only would I need to be able to convert a SearchQuery object into a string, but the hash would have to be perfect and not produce any collisions.
  2. Develop my own InMemory cache: What I’d really like is a Dictionary<SearchQuery, Results> object that persists in memory across all sessions. Since search results can start to get fairly large, I’d want to be able to cap how many queries would be cached and provide a way for older queries to expire. Something like a FIFO queue would work well here. I’m worried about things like thread safety, and am wondering if writing my own cache is worth the effort here.

I’ve also looked into some other third party cache providers such as NCache and Velocity. These are both distributed cache providers and are probably completely overkill for what I need at the moment. Plus, it seems every cache system I’ve seen still requires objects to be keyed by a string. Ideally, I want something that holds a cache in process, allows me to key by an object’s hash value, and allows me to control expiration times and priorities.

I’d appreciate any advice or references to free and preferably open source solutions that could help me out here. Thanks!

  • 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-28T13:38:06+00:00Added an answer on May 28, 2026 at 1:38 pm

    Based on what you are saying, I recommend you use System.Web.Caching and build that into your DataAccess layer shielding it from the rest of you system. When called you can make your real time query or pull from a cached object based on your business/application needs. I do this today, but with Memcached.

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

Sidebar

Related Questions

I have a mobile website that allows users to upload photos using the file
Let say I have a website that allows users to send articles on that
I have an entries controller that allows users to add contact information the website.
I have a website that allows multiple users to highlight multiple parts of a
Say I have a website that allows anyone to log in through oauth or
I have a requirement to setup a website that allows users, user blogs, a
I currently have a website (ASP.NET 3.5, IIS 7.0) that allows users to upload
I'm working on a company website that allows users to have their own homepage
I have a website that allows users to upload videos to it, After they
I have a website that allows users to login w/ their google account, http://urlme.cc

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.