EF实体框架数据操作接口(转)
//----------------------------------------------------------------
// Copyright (C) 2013 河南禄恒软件科技有限公司
//
// 功能描述:实体框架数据仓储的操作接口,包含增删改查接口
//
//----------------------------------------------------------------
using System;
using System.Linq;
using System.Linq.Expressions;
namespace Qmvc.DataAccess.EntityRepository
{
/// <summary>
///
/// </summary>
/// <typeparam name="T"></typeparam>
public interface IRepository<T> where T : class, new()
{
/// <summary>
/// 返回一个 System.Linq.IQueryable
/// </summary>
/// <returns>一个 System.Linq.IQueryable,包含满足由 predicate 指定的条件的元素</returns>
IQueryable<T> All();
/// <summary>
/// 返回一个 System.Linq.IQueryable,包含满足由 predicate 指定的条件的元素
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <returns>一个 System.Linq.IQueryable,包含满足由 predicate 指定的条件的元素</returns>
IQueryable<T> Where(Expression<Func<T, bool>> predicate);
/// <summary>
/// 返回一个 System.Linq.IQueryable,包含满足由 predicate 和 分页参数
/// 指定的条件的元素,并根据键对其元素排序
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <param name="pageSize">页大小</param>
/// <param name="pageIndex">页码</param>
/// <param name="orderingSelector">用于从元素中提取键的函数</param>
/// <param name="orderBy">排序类型</param>
/// <param name="recCount">总数量</param>
/// <returns>一个 System.Linq.IQueryable,包含满足由 predicate 和 分页参数
/// 指定的条件的元素,并根据键对其元素排序</returns>
IQueryable<T> Where<TKey>(Expression<Func<T, bool>> predicate, int pageSize, int pageIndex,
Expression<Func<T, TKey>> orderingSelector, OrderingOrders orderBy, out int recCount);
/// <summary>
/// 返回一个 System.Linq.IQueryable,包含满足由 predicate 指定的条件的元素,并根据键对其元素排序
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <param name="orderingSelector">用于从元素中提取键的函数</param>
/// <param name="orderBy">排序</param>
/// <returns>一个 System.Linq.IQueryable,包含满足由 predicate 指定的条件的元素,并根据键对其元素排序</returns>
IQueryable<T> Where<TKey>(Expression<Func<T,
bool>> predicate, Expression<Func<T, TKey>>
orderingSelector,
OrderingOrders orderBy);
/// <summary>
/// 返回一个 System.Linq.IQueryable,包含满足由 predicate 指定的条件的元素,并根据键对其元素排序
/// </summary>
/// <param name="sql"></param>
/// <param name="parameters"></param>
/// <typeparam name="TKey"></typeparam>
/// <returns>一个 System.Linq.IQueryable,包含满足由 predicate 指定的条件的元素,并根据键对其元素排序</returns>
IQueryable<T> Where<TKey>(string sql, params object[] parameters);
/// <summary>
/// 返回序列的唯一元素;如果该序列并非恰好包含一个元素,则会引发异常。
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <returns>单个元素</returns>
T Single(Expression<Func<T, bool>> predicate);
/// <summary>
/// 返回序列的唯一元素;如果该序列并非恰好包含一个元素,则会引发异常。
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <param name="orderingSelector">用于从元素中提取键的函数</param>
/// <param name="orderBy">排序</param>
/// <returns>单个元素</returns>
T Single<TKey>(Expression<Func<T, bool>> predicate,
Expression<Func<T, TKey>> orderingSelector,
OrderingOrders orderBy);
/// <summary>
/// 返回序列中满足指定条件的唯一元素;如果序列中不包含任何元素,则返回默认值
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <returns>唯一元素</returns>
T FirstOrDefault(Expression<Func<T, bool>> predicate);
/// <summary>
/// 返回序列中满足指定条件的唯一元素;如果序列中不包含任何元素,则返回默认值
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <param name="orderingSelector">用于从元素中提取键的函数</param>
/// <param name="orderBy">排序</param>
/// <returns>唯一元素</returns>
T FirstOrDefault<TKey>(Expression<Func<T, bool>>
predicate, Expression<Func<T, TKey>> orderingSelector,
OrderingOrders orderBy);
/// <summary>
/// 返回指定序列中满足条件的元素数量
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <returns>元素数量</returns>
int Count(Expression<Func<T, bool>> predicate);
/// <summary>
/// 将对象添加到当前实体集中的对象上下文
/// </summary>
/// <param name="entity">实体对象</param>
/// <returns>操作是否成功</returns>
bool Add(T entity);
/// <summary>
/// 将对象标记为待删除
/// </summary>
/// <param name="entity">实体对象</param>
/// <returns>操作是否成功</returns>
bool Delete(T entity);
/// <summary>
/// 将满足 predicate 指定的条件的元素对象标记为待删除
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <returns>操作是否成功</returns>
bool Delete(Expression<Func<T, bool>> predicate);
/// <summary>
/// 将满足 predicate 指定的条件的元素对象更新为满足 updatePredicate 条件的属性;如果 IsOwnContex == true,将对象保存到数据源
/// </summary>
/// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
/// <param name="updatePredicate">用于构建对象的函数</param>
/// <returns>操作是否成功</returns>
bool Update(Expression<Func<T, bool>> predicate, Expression<Func<T, T>> updatePredicate);
}
}
转自:http://www.cnblogs.com/henanluheng/p/3785311.html
EF实体框架数据操作接口(转)的更多相关文章
- BIM工程信息管理系统-EF实体框架数据操作基类
EF实体框架数据操作基类主要是规范增.改.查.分页.Lambda表达式条件处理,以及异步操作等特性,这样能够尽可能的符合基类这个特殊类的定义,实现功能接口的最大化重用和统一. 1.程序代码 /// & ...
- EF实体框架数据操作基类(转)
//----------------------------------------------------------------// Copyright (C) 2013 河南禄恒软件科技有限公司 ...
- EF实体框架处理实体之间关联关系与EF延迟机制(下)
在数据库中,表与表之间可能存在多种联系,比如,一对多,多对多的关系.当我们使用逻辑外键在数据库建立两张表之间的关系的时候,我们使用EF实体框架 必然也会将这种关系映射到我们的实体关系中来.所以,在我们 ...
- 【MVC 1】MVC+EF实体框架—原理解析
导读:在之前,我们学过了三层框架,即:UI.BLL.DAL.我们将页面显示.逻辑处理和数据访问进行分层,避免了一层.两层的混乱.而后,我们又在经典三层的基础上,应用设计模式:外观.抽象工厂+反射,使得 ...
- 【EF 1】EF实体框架 原理+实例
一.知识回顾 到目前为止,自己学到的链接数据库操作已经经历了几个阶段,分别是:学生信息管理和(第一次)机房收费时的直接连接数据库操作表格,然后是机房个人重构中应用的操作实体,在其中还利用了一个很重要的 ...
- EF实体框架之CodeFirst一
对于SQL Server.MySql.Oracle等这些传统的数据库,基本都是关系型数据库,都是体现实体与实体之间的联系,在以前开发时,可能先根据需求设计数据库,然后在写Model和业务逻辑,对于Mo ...
- EF实体框架之CodeFirst四
在EF实体框架之CodeFirst二中也提到数据库里面一般包括表.列.约束.主外键.级联操作.实体关系(E-R图).存储过程.视图.锁.事务.数据库结构更新等.前面几篇博客把表.存储过程.视图这些算是 ...
- C#.Net EF实体框架入门视频教程
当前位置: 主页 > 编程开发 > C_VC视频教程 > C#.Net EF实体框架入门视频教程 > kingstone金士顿手机内存卡16G仅65元 1.EF实体框架之增加查 ...
- Config File Settings Of EF——实体框架的配置文件设置
我亦MSDN 原文地址 http://msdn.microsoft.com/en-us/data/jj556606 Entity Framework allows a number of settin ...
随机推荐
- table布局的简单网页
---恢复内容开始--- 由于<body>标签的图片不能够拉伸, 解决办法: 1.图片不够大,又background属性不能拉伸图片: 2.只能用个div,把其z-index值设为负,并使 ...
- struts2值栈内部数据结构详解
值栈是struts2内部一片很重要的区域,我在初学的时候,发现对于值栈这个数据结构的理解不是很深刻.例如OGNLContext是什么,ActionContext和值栈有什么关系.为什么ActionCo ...
- linux cat 命令详解
linux cat 命令详解 http://linux.chinaunix.net/techdoc/system/2007/11/16/972467.shtml adb shell su //这个不一 ...
- MemCache缓存multiget hole详解
multiget 是什么 multiget 指的是从 memcache(或其他分布式缓存) 一次性获得多个键值,一般由 memcached client 自行实现. multiget hole是什么 ...
- JAVA方法03之动手动脑问题解决
动手动脑1.当JAVA里定义的函数中去掉static后,怎么办?(如下程序,将square()函数的static去掉) public class SquareIntTest { public stat ...
- WebService开发
一.什么是WebService: 简单通俗来说,就是企业之间.网站之间通过Internet来访问并使用在线服务,一些数据,由于安全性问题,不能提供数据库给其他单位使用,这时候可以使 用WebSer ...
- 限制textarea输入内容长度(多浏览器兼容、鼠标操作可控)
限制textarea的输入内容长度,当从键盘输入,内容长度达到最大值时,只有输入Backspace.Delete.左移动.右移动有效,当用鼠标粘贴内容,则只保留最大值长度的内容.从而控制textare ...
- jfinal基本应用 --报主键重复
在使用jfinal 的Model过程中有一个很怪异的问题,发布到服务器上,只要是往表中添加字段,就报主键重复. 1.我添加表的时候调用了 public void create(Map map){ St ...
- placeholder 使用
这个属性是用于INPUT当中. 实现效果: 1.鼠标点击进入<input type='buttom' placeholder='用户名'> 2.用户名内容消失:不在使用以前的Value,来 ...
- Format函数
Format是一个很常用,却又似乎很烦的方法,本人试图对这个方法的帮助进行一些翻译,让它有一个完整的概貌,以供大家查询之用: 首先看它的声明: function Format(const Format ...