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 ...
随机推荐
- 利用FlashPaper在web页面中显示PDF文件(兼容各浏览器)
应项目需求要把PDF内嵌到网页中显示,其中有了很多办法,比如用<embed/>元素放入PDF文件,但是效果不理想,浏览器兼容不理想,在ie9/8(其他版本没有测试)显示会提示下载pdf文件 ...
- iOS - Safe iOS 加密安全
1.Base64 编码 简介: Base64 是一种基于64个可打印字符来表示二进制数据的表示方法,可打印字符包括字母 A-Z.a-z.0-9,共 62 个字符,另外两个符号在不同的系统不同 +,/. ...
- MFC编程入门之二十一(常用控件:编辑框Edit Control)
上一节讲了静态文本框,本节讲的是编辑框(Edit Control)同样是一种很常用的控件,我们可以在编辑框中输入并编辑文本.在前面加法计算器的例子中已经演示了编辑框的基本应用.下面具体讲解编辑框的使用 ...
- 使用JDBC获取Oracle连接时报错
The Network Adapter could not establish the connection 网络适配器不能创建连接 作为初学者的来说,这个问题让我找了好多次,每次重新开启 ...
- Java_I/O输入输出_使用输入输出流读取文件,将一段文字加密后存入文件,然后读取,将加密前与后的文件输出
import java.io.*; public class Example { public static void main(String[] args) { char a[] = "今 ...
- 通过form表单获取值
<!DOCTYPE html><html> <head> <meta charset="utf-8" /> <title> ...
- 关于SAX
某天,看到一些资料. 发现输入文件是一个使用SAX技术存储的文件格式. 于是在网上找了不少资料 ; 感慨计算机的世界真的是太有趣了. 在此做个简单的介绍. 时间序列数据挖掘是利用数据挖掘技术对一组与 ...
- css样式大全
字体属性:(font) 大小 {font-size: x-large;}(特大) xx-small;(极小) 一般中文用不到,只要用数值就可以,单位:PX.PD 样式 {font-style: obl ...
- 即时聊天IM之二 openfire 整合现有系统用户
合肥程序员群:49313181. 合肥实名程序员群:128131462 (不愿透露姓名和信息者勿加入) Q Q:408365330 E-Mail:egojit@qq.com 综述: ...
- DataFormatString 转
数据绑定之DataFormatString 设定BoundField的DataFormatString,通常有以下几种 DataFormatString= "{0:C}" 货币,货 ...