NET Caching Library Help
AddOrGetExisting<T>(String,T,CacheItemPolicy,String) Method
Example 




KellermanSoftware.NetCachingLibrary Namespace > SmartCache Class > AddOrGetExisting Method : AddOrGetExisting<T>(String,T,CacheItemPolicy,String) Method
A unique identifier for the cache entry.
The object to insert.
An object that contains eviction details for the cache entry. This object provides more options for eviction than a simple absolute expiration.
Optional. A named region in the cache to which the cache entry can be added. The default value for the optional parameter is Default
Inserts a cache entry into the cache, specifying a key and a value for the cache entry, and information about how the entry will be evicted. The expiration policy will be the same for both the primary and secondary cache providers.
Syntax
'Declaration
 
Public Overloads Function AddOrGetExisting(Of T)( _
   ByVal key As System.String, _
   ByVal value As T, _
   ByVal policy As System.Runtime.Caching.CacheItemPolicy, _
   Optional ByVal regionName As System.String _
) As T
'Usage
 
Dim instance As SmartCache
Dim key As System.String
Dim value As T
Dim policy As System.Runtime.Caching.CacheItemPolicy
Dim regionName As System.String
Dim value As T
 
value = instance.AddOrGetExisting(Of T)(key, value, policy, regionName)
public T AddOrGetExisting<T>( 
   System.string key,
   T value,
   System.Runtime.Caching.CacheItemPolicy policy,
   System.string regionName
)
public: T* AddOrGetExisting<T>( 
   System.string* key,
   T* value,
   System.Runtime.Caching.CacheItemPolicy* policy,
   System.string* regionName
) 
public:
T^ AddOrGetExistinggeneric<typename T>
( 
   System.String^ key,
   T^ value,
   System.Runtime.Caching.CacheItemPolicy^ policy,
   System.String^ regionName
) 

Parameters

key
A unique identifier for the cache entry.
value
The object to insert.
policy
An object that contains eviction details for the cache entry. This object provides more options for eviction than a simple absolute expiration.
regionName
Optional. A named region in the cache to which the cache entry can be added. The default value for the optional parameter is Default

Type Parameters

T

Return Value

If a cache entry with the same key exists, the specified cache entry's value; otherwise, null.
Example
//Create a Primary Memory Cache with a backing File Cache
string directory = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), "KellermanSoftware", "NetCachingLibrary", "Tests");
SmartConfig config = new SmartConfig(new MemoryCacheProvider(), new FileCacheProvider(directory));
            
//Specify UserName and LicenseKey for Licensed Mode
//config.UserName = "my user name";
//config.LicenseKey = "my license key";
            
//Instantiate the cache
SmartCache cache = new SmartCache(config);
            
//Build parameters for the report
int month = DateTime.Now.Month;
int year = DateTime.Now.Year;
            
//Load the report from the database
List<ReportDetail> report = ReportLogic.MonthlySalesReport(month, year);
            
//Get the cache key based on the report parameters
string cacheKey = cache.BuildCacheKey("MonthlySalesReport", month, year);
            
CacheItemPolicy policy = new CacheItemPolicy()
{
	AbsoluteExpiration = DateTimeOffset.Now.AddMinutes(20),
	SlidingExpiration = SmartCache.NoSlidingExpiration
};
            
List<ReportDetail> result = cache.AddOrGetExisting<List<ReportDetail>>(cacheKey, report, policy, "Default");
            
if (result == null)
	Console.WriteLine("The item was added to the cache");
else
	Console.WriteLine("The item already exists in the cache");
'Create a Primary Memory Cache with a backing File Cache
Dim directory As String = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), "KellermanSoftware", "NetCachingLibrary", "Tests")
Dim config As New SmartConfig(New MemoryCacheProvider(), New FileCacheProvider(directory))
            
'Specify UserName and LicenseKey for Licensed Mode
'config.UserName = "my user name";
'config.LicenseKey = "my license key";
            
'Instantiate the cache
Dim cache As New SmartCache(config)
            
'Build parameters for the report
Dim month As Integer = Date.Now.Month
Dim year As Integer = Date.Now.Year
            
'Load the report from the database
Dim report As List(Of ReportDetail) = ReportLogic.MonthlySalesReport(month, year)
            
'Get the cache key based on the report parameters
Dim cacheKey As String = cache.BuildCacheKey("MonthlySalesReport", month, year)
            
Dim policy As New CacheItemPolicy() With {
	.AbsoluteExpiration = DateTimeOffset.Now.AddMinutes(20),
	.SlidingExpiration = SmartCache.NoSlidingExpiration
}
            
Dim result As List(Of ReportDetail) = cache.AddOrGetExisting(Of List(Of ReportDetail))(cacheKey, report, policy, "Default")
            
If result Is Nothing Then
	Console.WriteLine("The item was added to the cache")
Else
	Console.WriteLine("The item already exists in the cache")
End If
Requirements

Target Platforms: Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2

See Also

Reference

SmartCache Class
SmartCache Members
Overload List