Redis结合EntityFramework结合使用的操作类
最近一段时间在研究redis。 各种不懂, 各种问题。也看了N多的资料。
最终参照着 张占岭 的博客 http://www.cnblogs.com/lori/p/3435483.html 写了一套redis与entityframework结合的操作类。
如有什么不正确的地方,请指明。
using ServiceStack.Redis;
using ServiceStack.Redis.Generic;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Entity;
using System.Threading.Tasks;
using System.Linq.Expressions;
using ServiceStack.Redis.Pipeline;
using ServiceStack.Redis.Support;
using System.Data.SqlClient;
namespace Redis
{ /// <summary>
/// 操作redis与entity framework
/// </summary>
public class RedisRepository<TEntity> :
IDisposable
where TEntity : class
{
public DbContext context;
IRedisClient redisDB;
IRedisTypedClient<TEntity> redisTypedClient;
IRedisList<TEntity> table; public RedisRepository(DbContext context)
{
this.context = context;
redisDB = new RedisClient("192.168.2.47", );//redis服务IP和端口
redisTypedClient = redisDB.As<TEntity>();
table = redisTypedClient.Lists[typeof(TEntity).Name];
} #region Repository<TEntity>成员 /// <summary>
/// 添加一条数据,该操作会同时插入到mssql和redis
/// </summary>
/// <param name="item">数据模型</param>
/// <returns>是否成功,成功返回1,失败返回0</returns>
public int Insert(TEntity item)
{
int result = ;
if (item != null)
{
context.Set<TEntity>().Add(item);
result = context.SaveChanges();
if (result > )
{
Task.Run(async () => await AsyncAddEntity(item));//异步向redis插入数据。
}
}
return result;
} /// <summary>
/// 删除单条数据操作,同时删除redis和SqlServer
/// </summary>
/// <param name="keysValue">删除条件</param>
/// <returns>是否成功,成功返回1,失败返回0</returns>
public int Delete(params object[] keysValue)
{
var entity = context.Set<TEntity>().Find(keysValue);
context.Set<TEntity>().Remove(entity);
int result = context.SaveChanges();
if (result > )
{
Task.Run(async () => await AsyncDelEntity(entity));//异步删除一条数据
}
return result;
} /// <summary>
/// 修改操作,同时修改SqlServer和redis
/// </summary>
/// <param name="itemOld">旧数据</param>
/// <param name="item">新数据</param>
/// <returns>是否成功,成功返回1,失败返回0</returns>
public int Update(Func<TEntity, bool> func, TEntity item)
{
context.Entry<TEntity>(item).State = EntityState.Modified;
int result = context.SaveChanges();
if (result > )
{
Task.Run(async () => await AsyncEditEntity(func, item));//异步修改redis数据。
}
return result;
} /// <summary>
/// 批量删除数据 ,同时删除redis和SqlServer
/// </summary>
/// <param name="func">删除条件</param>
/// <returns>返回删除成功的行数</returns>
public int DeleteSelect(Func<TEntity, bool> func)
{
var entities = context.Set<TEntity>().Where(func);
context.Set<TEntity>().RemoveRange(entities);
int result = context.SaveChanges();
if (result > )
{
Task.Run(async () => await AsyncDelEntity(func));//异步删除redis数据。
}
return result;
} /// <summary>
/// 获取所有数据
/// </summary>
/// <returns></returns>
public IQueryable<TEntity> GetModel()
{
return table.GetAll().AsQueryable();
} /// <summary>
/// 获取分页数据
/// </summary>
/// <param name="func">查询条件</param>
/// <param name="keySelector">排序字段</param>
/// <param name="pageIndex">获取页面的页数</param>
/// <param name="pageSize">页面行数</param>
/// <param name="totalPage">返回数据行总数</param>
/// <returns></returns>
public IList<TEntity> GetModel(Func<TEntity, bool> func, Func<TEntity, object> keySelector, int pageIndex, int pageSize, out int totalPage)
{
int startRow = (pageIndex - ) * pageSize;
totalPage = table.Count();
//判断缓存中数据是否为空并且数据库内数据行数是否与缓存中行数一致,如果为空或者不一致 从数据库查询数据 异步插入到缓存中。
int dbCount = context.Set<TEntity>().Count();
if (dbCount != totalPage || totalPage == )
{
totalPage = dbCount;
List<TEntity> listDB = context.Set<TEntity>().AsQueryable().ToList();
Task.Run(async () => await AsyncAddEntity(listDB));//异步向redis插入数据。
return context.Set<TEntity>().AsQueryable().Where(func).OrderBy(keySelector).Skip(startRow).Take(pageSize).ToList();
}
return table.GetAll().AsQueryable().Where(func).OrderBy(keySelector).Skip(startRow).Take(pageSize).ToList();
} /// <summary>
/// 查询单条数据
/// </summary>
/// <param name="func">查询条件</param>
/// <returns></returns>
public TEntity Find(Func<TEntity, bool> func)
{
return table.Where(func).FirstOrDefault();
} /// <summary>
/// 异步插入到redis列表
/// </summary>
/// <param name="listDB"></param>
/// <returns></returns>
private Task AsyncAddEntity(List<TEntity> listDB)
{
return Task.Factory.StartNew(() =>
{
table.RemoveAll();
listDB.ForEach(m => redisTypedClient.AddItemToList(table, m));
redisDB.Save();
});
} /// <summary>
/// 异步插入到redis单条
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
private Task AsyncAddEntity(TEntity entity)
{
return Task.Factory.StartNew(() =>
{
redisTypedClient.AddItemToList(table, entity);
redisDB.Save();
});
} /// <summary>
/// 异步删除一条数据
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
private Task AsyncDelEntity(TEntity entity)
{
return Task.Factory.StartNew(() =>
{
redisTypedClient.RemoveItemFromList(table, entity);
redisDB.Save();
});
}
private Task AsyncDelEntity(Func<TEntity, bool> func)
{
return Task.Factory.StartNew(() =>
{
table.GetAll().AsQueryable().Where(func).ToList().ForEach(m => redisTypedClient.RemoveItemFromList(table, m));
redisDB.Save();
});
}
/// <summary>
/// 修改一条数据
/// </summary>
/// <param name="func"></param>
/// <param name="item"></param>
/// <returns></returns>
private Task AsyncEditEntity(Func<TEntity, bool> func, TEntity item)
{
return Task.Factory.StartNew(() =>
{
redisTypedClient.RemoveItemFromList(table, Find(func));
redisTypedClient.AddItemToList(table, item);
redisDB.Save();
});
} #endregion #region IDisposable成员
public void Dispose()
{
this.ExplicitDispose();
}
#endregion #region Protected Methods /// <summary>
/// 垃圾回收
/// </summary>
protected void ExplicitDispose()
{
this.Dispose(true);
GC.SuppressFinalize(this);
} protected void Dispose(bool disposing)
{
if (disposing)//清除非托管资源
{
table = null;
redisTypedClient = null;
redisDB.Dispose();
}
}
#endregion #region Finalization Constructs
/// <summary>
/// Finalizes the object.
/// </summary>
~RedisRepository()
{
this.Dispose(false);
}
#endregion
}
}
Redis结合EntityFramework结合使用的操作类的更多相关文章
- 使用RedisTemplate的操作类访问Redis(转)
深入理解Spring Redis的使用 (三).使用RedisTemplate的操作类访问Redis 事务需要开启enableTransactionSupport,然后使用@transactional ...
- php的redis 操作类,适用于单台或多台、多组redis服务器操作
redis 操作类,包括单台或多台.多组redis服务器操作,适用于业务复杂.高性能要求的 php web 应用. redis.php: <?php /* redis 操作类,适用于单台或多台. ...
- php redis数据库操作类
<?php namespace iphp\db; use iphp\App; /** * redis操作类 * 说明,任何为false的串,存在redis中都是空串. * 只有在key不存在时, ...
- 设计模式之PHP项目应用——单例模式设计Memcache和Redis操作类
1 单例模式简单介绍 单例模式是一种经常使用的软件设计模式. 在它的核心结构中仅仅包括一个被称为单例类的特殊类. 通过单例模式能够保证系统中一个类仅仅有一个实例并且该实例易于外界訪问.从而方便对实例个 ...
- 深入理解Spring Redis的使用 (三)、使用RedisTemplate的操作类访问Redis
上一篇说了RedisTemplate对注解事务的支持,以及提供的序列化器. 事务需要开启enableTransactionSupport,然后使用@transactional注解,里面直接通过回调的c ...
- 封装php redis缓存操作类
封装php redis缓存操作类,集成了连接redis并判断连接是否成功,redis数据库选择,检测redis键是否存在,获取值,写入值,设置生存时间和删除清空操作. php redis类代码: &l ...
- 【PHP+Redis】 php-redis 操作类 封装
<?php /** * redis操作类 * 说明,任何为false的串,存在redis中都是空串. * 只有在key不存在时,才会返回false. * 这点可用于防止缓存穿透 * */ cla ...
- 使用RedisTemplate的操作类访问Redis(转载)
原文地址:http://www.cnblogs.com/luochengqiuse/p/4641256.html private ValueOperations<K, V> valueOp ...
- ecshop的Mysql操作类
摘要,这是直接摘抄的ecshop的mysql操作类:不过他这里的缓存是用的文件缓存,我们如果想直接使用,可以替换成memcache的或者redis的! <?php /** * ECSHOP MY ...
随机推荐
- Ant工具
Ant工具 Ant是一种基于Java的build工具.理论上来说,它有些类似于(Unix)C中的make ,但没有make的缺陷.目前的最新版本为:Ant 1.9.4[1] . Ant的概念 当一 ...
- 硬编码写RadioGroup的时候要注意设置RadioButton的Id
硬编码写RadioGroup的时候要注意RadioButton的id重复问题,导致选择的时候出现能够多选的情况发生,如下代码,注意Id的设置,这样避免Radiobutton的id重复. /** * 生 ...
- c# try..... catch
功能说明:在此例中,try 块包含对可能导致异常的ProcessString()方法的调用.catch子句包含仅在屏幕上显示消息的异常处理程序,当从ProcessString内部调用throw语句时, ...
- android入门系列- TextView EditText Button ImageView 的简单应用
第一篇原创,其实自己就是一菜鸟,简单分享点基本知识吧.希望能有所帮助吧. TextView EditText Button ImageView 这几个控件可能是Android开发中最常用.最基本的几个 ...
- SQL拾遗
前两天同事问了个SQL问题,有个出价记录表[针对不同拍品出价],每个人都可以多次出价,要查下哪些拍品出价最高的人和出价次高的人是同一个人的记录,当时写了下面的SQL,今天先记下了,欢迎补充新的查询方式 ...
- 利用Graphviz 画结构图[转]
转自:http://www.cnblogs.com/sld666666/archive/2010/06/25/1765510.html 利用Graphviz 画结构图 1. Graphviz介绍 ...
- Index Full Scan vs Index Fast Full Scan-1103
[Oracle] Index Full Scan vs Index Fast Full Scan作者:汪海 (Wanghai) 日期:14-Aug-2005 出处:http://spaces.msn. ...
- CSRF 攻击的应对之道
转载自imb文库 CSRF(Cross Site Request Forgery, 跨站域请求伪造)是一种网络的攻击方式,该攻击可以在受害者毫不知情的情况下以受害者名义伪造请求发送给受攻击站点,从而在 ...
- 在Mac OS上搭建本地服务器
我们在做网络编程的时候一般是需要有网络环境的,这样可以边写边测试达到很高的效率.但有些时候我们由于很多原因我们的电脑无法连接到网络,这时就会感觉很不自在,所以今天在这里教大家怎么用自己电脑作服务器. ...
- 使用EasyUI导入的js顺序
使用Jquery Easy UI要导入的js顺序<1>.引用Jquery的Js文件<script src="jquery-easyui-1.3.4/jquery-1.8.0 ...