mirror of
https://gitee.com/dotnetchina/SqlSugar.git
synced 2025-08-23 22:11:36 +08:00
-
This commit is contained in:
parent
4621b46c11
commit
47c292fe3e
17
Src/Asp.NetCore2/SqlSeverTest/CacheTest/CacheTest.csproj
Normal file
17
Src/Asp.NetCore2/SqlSeverTest/CacheTest/CacheTest.csproj
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
|
<PropertyGroup>
|
||||||
|
<OutputType>Exe</OutputType>
|
||||||
|
<TargetFramework>netcoreapp3.1</TargetFramework>
|
||||||
|
</PropertyGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<PackageReference Include="Microsoft.Extensions.Caching.Abstractions" Version="5.0.0" />
|
||||||
|
<PackageReference Include="Microsoft.Extensions.Caching.Memory" Version="5.0.0" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<ProjectReference Include="..\SqlSugar\SqlSugar.csproj" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
</Project>
|
282
Src/Asp.NetCore2/SqlSeverTest/CacheTest/MemoryCacheHelper.cs
Normal file
282
Src/Asp.NetCore2/SqlSeverTest/CacheTest/MemoryCacheHelper.cs
Normal file
@ -0,0 +1,282 @@
|
|||||||
|
using Microsoft.Extensions.Caching.Memory;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using SqlSugar;
|
||||||
|
using System.Reflection;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Text.RegularExpressions;
|
||||||
|
|
||||||
|
namespace CacheTest
|
||||||
|
{
|
||||||
|
public class SugarCache : ICacheService
|
||||||
|
{
|
||||||
|
MemoryCacheHelper cache = new MemoryCacheHelper();
|
||||||
|
public void Add<V>(string key, V value)
|
||||||
|
{
|
||||||
|
cache.Set(key, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Add<V>(string key, V value, int cacheDurationInSeconds)
|
||||||
|
{
|
||||||
|
cache.Set(key, value,cacheDurationInSeconds);
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool ContainsKey<V>(string key)
|
||||||
|
{
|
||||||
|
return cache.Exists(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public V Get<V>(string key)
|
||||||
|
{
|
||||||
|
return cache.Get<V>(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public IEnumerable<string> GetAllKey<V>()
|
||||||
|
{
|
||||||
|
return cache.GetCacheKeys();
|
||||||
|
}
|
||||||
|
|
||||||
|
public V GetOrCreate<V>(string cacheKey, Func<V> create, int cacheDurationInSeconds = int.MaxValue)
|
||||||
|
{
|
||||||
|
if (cache.Exists(cacheKey))
|
||||||
|
{
|
||||||
|
return cache.Get<V>(cacheKey);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var result = create();
|
||||||
|
cache.Set(cacheKey, result, cacheDurationInSeconds);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Remove<V>(string key)
|
||||||
|
{
|
||||||
|
cache.Remove(key);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public class MemoryCacheHelper
|
||||||
|
{
|
||||||
|
private static readonly MemoryCache Cache = new MemoryCache(new MemoryCacheOptions());
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 验证缓存项是否存在
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key">缓存Key</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public bool Exists(string key)
|
||||||
|
{
|
||||||
|
if (key == null)
|
||||||
|
throw new ArgumentNullException(nameof(key));
|
||||||
|
return Cache.TryGetValue(key, out _);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 添加缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key">缓存Key</param>
|
||||||
|
/// <param name="value">缓存Value</param>
|
||||||
|
/// <param name="expiresSliding">滑动过期时长(如果在过期时间内有操作,则以当前时间点延长过期时间)</param>
|
||||||
|
/// <param name="expiressAbsoulte">绝对过期时长</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public bool Set(string key, object value, TimeSpan expiresSliding, TimeSpan expiressAbsoulte)
|
||||||
|
{
|
||||||
|
if (key == null)
|
||||||
|
throw new ArgumentNullException(nameof(key));
|
||||||
|
if (value == null)
|
||||||
|
throw new ArgumentNullException(nameof(value));
|
||||||
|
|
||||||
|
Cache.Set(key, value,
|
||||||
|
new MemoryCacheEntryOptions().SetSlidingExpiration(expiresSliding)
|
||||||
|
.SetAbsoluteExpiration(expiressAbsoulte));
|
||||||
|
return Exists(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 添加缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key">缓存Key</param>
|
||||||
|
/// <param name="value">缓存Value</param>
|
||||||
|
/// <param name="expiresIn">缓存时长</param>
|
||||||
|
/// <param name="isSliding">是否滑动过期(如果在过期时间内有操作,则以当前时间点延长过期时间)</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public bool Set(string key, object value, TimeSpan expiresIn, bool isSliding = false)
|
||||||
|
{
|
||||||
|
if (key == null)
|
||||||
|
throw new ArgumentNullException(nameof(key));
|
||||||
|
if (value == null)
|
||||||
|
throw new ArgumentNullException(nameof(value));
|
||||||
|
|
||||||
|
Cache.Set(key, value,
|
||||||
|
isSliding
|
||||||
|
? new MemoryCacheEntryOptions().SetSlidingExpiration(expiresIn)
|
||||||
|
: new MemoryCacheEntryOptions().SetAbsoluteExpiration(expiresIn));
|
||||||
|
|
||||||
|
return Exists(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 添加缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key">缓存Key</param>
|
||||||
|
/// <param name="value">缓存Value</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public void Set(string key, object value)
|
||||||
|
{
|
||||||
|
Set(key, value, TimeSpan.FromDays(1));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 添加缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key">缓存Key</param>
|
||||||
|
/// <param name="value">缓存Value</param>
|
||||||
|
/// <param name="ts"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public void Set(string key, object value, TimeSpan ts)
|
||||||
|
{
|
||||||
|
Set(key, value, ts, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 添加缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key">缓存Key</param>
|
||||||
|
/// <param name="value">缓存Value</param>
|
||||||
|
/// <param name="ts"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public void Set(string key, object value, int seconds)
|
||||||
|
{
|
||||||
|
var ts = TimeSpan.FromSeconds(seconds);
|
||||||
|
Set(key, value, ts, false);
|
||||||
|
}
|
||||||
|
#region 删除缓存
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 删除缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key">缓存Key</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public void Remove(string key)
|
||||||
|
{
|
||||||
|
if (key == null)
|
||||||
|
throw new ArgumentNullException(nameof(key));
|
||||||
|
Cache.Remove(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 批量删除缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <returns></returns>
|
||||||
|
public void RemoveAll(IEnumerable<string> keys)
|
||||||
|
{
|
||||||
|
if (keys == null)
|
||||||
|
throw new ArgumentNullException(nameof(keys));
|
||||||
|
|
||||||
|
keys.ToList().ForEach(item => Cache.Remove(item));
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region 获取缓存
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 获取缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key">缓存Key</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public T Get<T>(string key)
|
||||||
|
{
|
||||||
|
if (key == null)
|
||||||
|
throw new ArgumentNullException(nameof(key));
|
||||||
|
|
||||||
|
return Cache.Get<T>(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 获取缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="key">缓存Key</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public object Get(string key)
|
||||||
|
{
|
||||||
|
if (key == null)
|
||||||
|
throw new ArgumentNullException(nameof(key));
|
||||||
|
|
||||||
|
return Cache.Get(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 获取缓存集合
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="keys">缓存Key集合</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public IDictionary<string, object> GetAll(IEnumerable<string> keys)
|
||||||
|
{
|
||||||
|
if (keys == null)
|
||||||
|
throw new ArgumentNullException(nameof(keys));
|
||||||
|
|
||||||
|
var dict = new Dictionary<string, object>();
|
||||||
|
keys.ToList().ForEach(item => dict.Add(item, Cache.Get(item)));
|
||||||
|
return dict;
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 删除所有缓存
|
||||||
|
/// </summary>
|
||||||
|
public void RemoveCacheAll()
|
||||||
|
{
|
||||||
|
var l = GetCacheKeys();
|
||||||
|
foreach (var s in l)
|
||||||
|
{
|
||||||
|
Remove(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 删除匹配到的缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="pattern"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public void RemoveCacheRegex(string pattern)
|
||||||
|
{
|
||||||
|
IList<string> l = SearchCacheRegex(pattern);
|
||||||
|
foreach (var s in l)
|
||||||
|
{
|
||||||
|
Remove(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 搜索 匹配到的缓存
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="pattern"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public IList<string> SearchCacheRegex(string pattern)
|
||||||
|
{
|
||||||
|
var cacheKeys = GetCacheKeys();
|
||||||
|
var l = cacheKeys.Where(k => Regex.IsMatch(k, pattern)).ToList();
|
||||||
|
return l.AsReadOnly();
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 获取所有缓存键
|
||||||
|
/// </summary>
|
||||||
|
/// <returns></returns>
|
||||||
|
public List<string> GetCacheKeys()
|
||||||
|
{
|
||||||
|
const BindingFlags flags = BindingFlags.Instance | BindingFlags.NonPublic;
|
||||||
|
var entries = Cache.GetType().GetField("_entries", flags).GetValue(Cache);
|
||||||
|
var cacheItems = entries as IDictionary;
|
||||||
|
var keys = new List<string>();
|
||||||
|
if (cacheItems == null) return keys;
|
||||||
|
foreach (DictionaryEntry cacheItem in cacheItems)
|
||||||
|
{
|
||||||
|
keys.Add(cacheItem.Key.ToString());
|
||||||
|
}
|
||||||
|
return keys;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
23
Src/Asp.NetCore2/SqlSeverTest/CacheTest/Program.cs
Normal file
23
Src/Asp.NetCore2/SqlSeverTest/CacheTest/Program.cs
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
using System;
|
||||||
|
|
||||||
|
namespace CacheTest
|
||||||
|
{
|
||||||
|
class Program
|
||||||
|
{
|
||||||
|
static void Main(string[] args)
|
||||||
|
{
|
||||||
|
SugarCache cache = new SugarCache();
|
||||||
|
cache.Add("a", "1");
|
||||||
|
|
||||||
|
var x = cache.Get<string>("a");
|
||||||
|
cache.Add("a2", "11",5);
|
||||||
|
var x2 = cache.Get<string>("a2");
|
||||||
|
var isa= cache.ContainsKey<string>("a2");
|
||||||
|
var allKeys = cache.GetAllKey<string>();
|
||||||
|
var testr=cache.GetOrCreate<string>("a33",()=> { return "aaa"; },10);
|
||||||
|
cache.Remove<string>("aaaaaaaa");
|
||||||
|
cache.Remove<string>("a");
|
||||||
|
Console.WriteLine("Hello World!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -17,9 +17,11 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "NugetTest", "NugetTest\Nuge
|
|||||||
EndProject
|
EndProject
|
||||||
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "PgSqlTest", "PgSqlTest\PgSqlTest.csproj", "{B9005A73-5307-48FB-90EA-CC18FE6926E2}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "PgSqlTest", "PgSqlTest\PgSqlTest.csproj", "{B9005A73-5307-48FB-90EA-CC18FE6926E2}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "DmOrmTest", "DmOrmTest\DmOrmTest.csproj", "{FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "DmOrmTest", "DmOrmTest\DmOrmTest.csproj", "{FBA1A5CC-1C9D-476F-B19D-FD5E2201C30A}"
|
||||||
EndProject
|
EndProject
|
||||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "KdbndpTest", "KdbndpTest\KdbndpTest.csproj", "{21744B61-74AB-4706-9A52-C9D0C4AAD19E}"
|
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "KdbndpTest", "KdbndpTest\KdbndpTest.csproj", "{21744B61-74AB-4706-9A52-C9D0C4AAD19E}"
|
||||||
|
EndProject
|
||||||
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "CacheTest", "CacheTest\CacheTest.csproj", "{2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}"
|
||||||
EndProject
|
EndProject
|
||||||
Global
|
Global
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
@ -63,6 +65,10 @@ Global
|
|||||||
{21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
{21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
{21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
{21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
{21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|Any CPU.Build.0 = Release|Any CPU
|
{21744B61-74AB-4706-9A52-C9D0C4AAD19E}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
|
{2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||||
|
{2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||||
|
{2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||||
|
{2EC6C9BD-6B8F-4EC3-B4ED-EAEFD8BB735C}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
HideSolutionNode = FALSE
|
HideSolutionNode = FALSE
|
||||||
|
Loading…
Reference in New Issue
Block a user