• using System;
  • using System.Linq;
  • using System.Linq.Expressions;
  • using System.Data.Objects;
  • namespace HENANLUHENG.Framework.EntityRepository
  • {
  • 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="orderingWhereor">用于从元素中提取键的函数</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>> orderingWhereor, OrderingOrders orderBy, out int recCount);
  • /// <summary>
  • /// 返回一个 System.Linq.IQueryable,包含满足由 predicate 指定的条件的元素,并根据键对其元素排序
  • /// </summary>
  • /// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
  • /// <param name="orderingWhereor">用于从元素中提取键的函数</param>
  • /// <param name="orderBy">排序</param>
  • /// <returns>一个 System.Linq.IQueryable,包含满足由 predicate 指定的条件的元素,并根据键对其元素排序</returns>
  • IQueryable<T> Where<TKey>(Expression<Func<T, bool>> predicate, Expression<Func<T, TKey>> orderingWhereor, OrderingOrders orderBy);
  • /// <summary>
  • /// 返回一个 System.Linq.IQueryable,包含满足指定的条件的元素,并根据键对其元素排序
  • /// </summary>
  • /// <param name="conditions">条件T-Sql语句</param>
  • /// <param name="objParams">参数</param>
  • /// <returns>一个 System.Linq.IQueryable,包含满足指定的条件的元素,并根据键对其元素排序</returns>
  • IQueryable<T> Where(string conditions, ObjectParameter[] objParams = null);
  • /// <summary>
  • /// 返回一个 System.Linq.IQueryable,包含满足指定的条件的元素,并根据键对其元素排序
  • /// </summary>
  • /// <param name="conditions">条件T-Sql语句</param>
  • /// <param name="pageSize">页大小</param>
  • /// <param name="pageIndex">页码</param>
  • /// <param name="orderByStr">排序T-Sql语句</param>
  • /// <param name="recCount">总数量</param>
  • /// <param name="objParams">参数</param>
  • /// <returns>一个 System.Linq.IQueryable,包含满足指定的条件的元素,并根据键对其元素排序</returns>
  • IQueryable<T> Where(string conditions, int pageSize, int pageIndex, string orderByStr, out int recCount, ObjectParameter[] objParams = null);
  • /// <summary>
  • /// 返回序列的唯一元素;如果该序列并非恰好包含一个元素,则会引发异常。
  • /// </summary>
  • /// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
  • /// <returns>单个元素</returns>
  • T Single(Expression<Func<T, bool>> predicate);
  • /// <summary>
  • /// 返回序列的唯一元素;如果该序列并非恰好包含一个元素,则会引发异常。
  • /// </summary>
  • /// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
  • /// <param name="orderingWhereor">用于从元素中提取键的函数</param>
  • /// <param name="orderBy">排序</param>
  • /// <returns>单个元素</returns>
  • T Single<TKey>(Expression<Func<T, bool>> predicate, Expression<Func<T, TKey>> orderingWhereor, 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="orderingWhereor">用于从元素中提取键的函数</param>
  • /// <param name="orderBy">排序</param>
  • /// <returns>唯一元素</returns>
  • T FirstOrDefault<TKey>(Expression<Func<T, bool>> predicate, Expression<Func<T, TKey>> orderingWhereor, 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>
  • /// 将满足 指定的条件的元素对象标记为待删除;如果 IsOwnContex == true,将对象保存到数据源
  • /// </summary>
  • /// <param name="conditions">条件T-Sql语句</param>
  • /// <returns>操作是否成功</returns>
  • bool Delete(string conditions);
  • /// <summary>
  • /// 将满足 predicate 指定的条件的元素对象标记为待删除
  • /// </summary>
  • /// <param name="predicate">用于测试每个元素是否满足条件的函数</param>
  • /// <returns>操作是否成功</returns>
  • bool Delete(Expression<Func<T, bool>> predicate);
  • /// <summary>
  • ///     临时把实休对象保存在管理对象中
  • /// </summary>
  • /// <param name="entity"></param>
  • void AddEntity(T entity);
  • }
  • }

转自:http://www.cnblogs.com/henanluheng/p/3523896.html

EF快速开发定义数据接口类(转)的更多相关文章

  1. C++:如何正确的定义一个接口类

    C++中如何定义接口类?首先给接口类下了定义:接口类应该是只提供方法声明,而自身不提供方法定义的抽象类.接口类自身不能实例化,接口类的方法定义/实现只能由接口类的子类来完成. 而对于C++,其接口类一 ...

  2. 使用Asp.net WebAPI 快速构建后台数据接口

    现在的互联网应用,无论是web应用,还是移动APP,基本都需要实现非常多的数据访问接口.其实对一些轻应用来说Asp.net WebAPI是一个很快捷简单并且易于维护的后台数据接口框架.下面我们来快速构 ...

  3. GIS应用|快速开发REST数据服务

    随着计算机的快速发展,GIS已经在各大领域得到应用,和我们的生活息息相关, 但是基于GIS几大厂商搭建服务,都会有一定的门槛,尤其是需要server,成本高,难度大,这里介绍一种在线GIS云平台,帮你 ...

  4. Android 开发 SharedPreferences数据会话类模板

    简单的模板 public class SPDataSession { private static SPDataSession mSPDataSession; private SharedPrefer ...

  5. python开发面向对象基础:接口类&抽象类&多态&钻石继承

    一,接口类 继承有两种用途: 一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类Interface,接口类中定义了一些接口名(就是函数名)且并未实 ...

  6. 基于ABP开发框架的技术点分析和项目快速开发实现

    在我们开发各种项目应用的时候,往往都是基于一定框架进行,同时配合专用的代码生成工具,都是为了快速按照固定模式开发项目,事半功倍,本篇随笔对基于ABP开发框架的技术点进行分析和ABP框架项目快速开发实现 ...

  7. Python--抽象类接口类

    一. 继承有两种用途: """ 一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类Interface,接口类中定义了 ...

  8. python之路----继承的抽象类和接口类

    抽象类与接口类 接口类 继承有两种用途: 一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类Interface,接口类中定义了一些接口名(就是函数 ...

  9. day24-抽象类与接口类

    接口类 1.继承有两种用途:一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类,接口类中定义了一些接口名(就是函数名)且并未实现接口的功能,子类继 ...

随机推荐

  1. MFC编程入门之二十五(常用控件:组合框控件ComboBox)

    上一节讲了列表框控件ListBox的使用,本节主要讲解组合框控件Combo Box.组合框同样相当常见,例如,在Windows系统的控制面板上设置语言或位置时,有很多选项,用来进行选择的控件就是组合框 ...

  2. Tableau(数据抽取)

    如果启用的是标准的企业数据库,TABLEAU中做实时分析会比较困难,例如以下情况:(1)不在办公室,无法连接到数据库:(2)在Microsoft SQL Server或者Oracle,在数据库很大或者 ...

  3. linux下使用yum安装Apache+php+Mysql+phpMyAdmin

    适用redhat于32位及64位,前提架设好本地源.在这里不再赘述. 1 安装Apache+php+Mysql a.安装Apahce, PHP, Mysql, 以及php连接mysql库组件 yum ...

  4. spring 声明式事务管理

    简单理解事务: 比如你去ATM机取5000块钱,大体有两个步骤:首先输入密码金额,银行卡扣掉5000元钱:然后ATM出5000元钱.这两个步骤必须是要么都执行要么都不执行.如果银行卡扣除了5000块但 ...

  5. Guava----Function

    1. Function接口,提供两个方法: apply方法: 可以自定义自己想实现的功能 @Nullable T apply(@Nullable F input); 1. 实例: import com ...

  6. 数组中的toString,toLocalString,valueOf方法有什么区别

    1. 2.简单来说,tostring就是用字符串来代替对象.tolocalstring就是根据不同的语言环境吧对象转成字符串,实际上totolocalstring是有缺省参数的,如tolocalstr ...

  7. iOS:使用代理模式监听开关状态改变事件

    记一次解决跨控制器监听开关状态改变的尝试. 为了统一设置UITableViewCell里的内容,自定义了UITableViewCell类的一个基类,命名为SettingCell.SettingCell ...

  8. jQuery验证插件 Validate详解

    1.引入必要的文件,以及语言中文提示包 2.使用规则如下: 序号 规则 描述 1 required:true 必须输入的字段. 2 remote:"check.php" 使用 aj ...

  9. Windows Store App 网络通信 HttpClient

    HttpClient类包含在System.Net.Http命名空间中,是向以URI标识的网络资源发送HTTP请求和接收HTTP响应的基类.在HTTP请求中使用该类可以向Web服务发送GET.POST等 ...

  10. JavaScript基础之DOM修改样式

    1.获取或设置元素的内容:3个属性:   1. innerHTML: 获取或设置元素开始标签到结束标签之间的所有HTML代码原文.      何时使用:只要获得完整的html代码原文时      优化 ...