What are some database caching options for .Net?

2019-05-31 18:35发布

I see on the web there are a lot of questions about caching ASP.Net, but not a lot of discussion on caching options for a Smart Client Application and their databases.

What are the data caching options that are available for Smart Client Application on the .Net framework, and how are any of you using them?


Edit

Enterprise Framework was mentioned below, thoughts?

3条回答
一夜七次
2楼-- · 2019-05-31 19:01

Well, if you have a Windows Forms application, you aren't usually concerned with the types of multi-user caching scenarios that are common in ASP.NET. I think that's why you aren't seeing a lot of documentation on the subject here.

I generally roll my own caching mechanism for Windows Forms -- just storing "cached" stuff as the application's state. Do you have any examples of a scenario where you would need it? The solution should be tailored to fit the problem...

查看更多
趁早两清
3楼-- · 2019-05-31 19:11

Caching frequently accessed data is required/desirable in Winforms Smart Client applications. Reading data from cache is often faster than hitting your data providers/web services.

Here are a couple of options with examples

  1. Enterprise library's caching application block is a good choice.
  2. Also, System.Web.Caching.Cache can be used with Winforms, just get a static instance.

See the example below.

With Entlib

 using Microsoft.Practices.EnterpriseLibrary.Caching;
    //Later 
    CacheManager cache= CacheFactory.GetCacheManager(); 
    cache.Add("dataKey", "Yourdata")

With .NET built-in cache - This'll work for your Winform app also.

using System.Web.Caching;
using System.Web;

public sealed class CacheProvider 
{ 
    private CacheProvider(){}; 

    public static GetInstance() 
    {  
            return HttpRuntime.Cache;
    } 
}
查看更多
看我几分像从前
4楼-- · 2019-05-31 19:15

Velocity is another option.

查看更多
登录 后发表回答