EF快速开发定义数据接口类(转)
- 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快速开发定义数据接口类(转)的更多相关文章
- C++:如何正确的定义一个接口类
C++中如何定义接口类?首先给接口类下了定义:接口类应该是只提供方法声明,而自身不提供方法定义的抽象类.接口类自身不能实例化,接口类的方法定义/实现只能由接口类的子类来完成. 而对于C++,其接口类一 ...
- 使用Asp.net WebAPI 快速构建后台数据接口
现在的互联网应用,无论是web应用,还是移动APP,基本都需要实现非常多的数据访问接口.其实对一些轻应用来说Asp.net WebAPI是一个很快捷简单并且易于维护的后台数据接口框架.下面我们来快速构 ...
- GIS应用|快速开发REST数据服务
随着计算机的快速发展,GIS已经在各大领域得到应用,和我们的生活息息相关, 但是基于GIS几大厂商搭建服务,都会有一定的门槛,尤其是需要server,成本高,难度大,这里介绍一种在线GIS云平台,帮你 ...
- Android 开发 SharedPreferences数据会话类模板
简单的模板 public class SPDataSession { private static SPDataSession mSPDataSession; private SharedPrefer ...
- python开发面向对象基础:接口类&抽象类&多态&钻石继承
一,接口类 继承有两种用途: 一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类Interface,接口类中定义了一些接口名(就是函数名)且并未实 ...
- 基于ABP开发框架的技术点分析和项目快速开发实现
在我们开发各种项目应用的时候,往往都是基于一定框架进行,同时配合专用的代码生成工具,都是为了快速按照固定模式开发项目,事半功倍,本篇随笔对基于ABP开发框架的技术点进行分析和ABP框架项目快速开发实现 ...
- Python--抽象类接口类
一. 继承有两种用途: """ 一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类Interface,接口类中定义了 ...
- python之路----继承的抽象类和接口类
抽象类与接口类 接口类 继承有两种用途: 一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类Interface,接口类中定义了一些接口名(就是函数 ...
- day24-抽象类与接口类
接口类 1.继承有两种用途:一:继承基类的方法,并且做出自己的改变或者扩展(代码重用) 二:声明某个子类兼容于某基类,定义一个接口类,接口类中定义了一些接口名(就是函数名)且并未实现接口的功能,子类继 ...
随机推荐
- 启动windows bat文件出现错误,直接关闭
如果执行运行run.bat,提示错误直接退出后,可以直接使用cmd命令进入当前目录,运行,会显示错误信息.
- md语法之行内代码和代码片
md语法之行内代码和代码片 比如说要在行内写上一句或者半句代码(代码的意思就是某种脚本语言), 用撇号围起来就可以了. 比如: import pandas as pd 写代码片(单独的一块脚本语言)的 ...
- Android UiAutomator快速调试
在测试类中添加主函数 public static void main(String[] args){ String jarName,testClass, testName,androidId; jar ...
- java中Array/List/Map/Object与Json互相转换详解
http://blog.csdn.net/xiaomu709421487/article/details/51456705 JSON(JavaScript Object Notation): 是一种轻 ...
- json数组转普通数组 普通数组转json数组
1.json_decode() json_decode (PHP 5 >= 5.2.0, PECL json >= 1.2.0) json_decode — 对 JSON 格式的字符串进行 ...
- 不在折腾---hive-0.13.1-bin
Hive只在一个节点安装即可 上传tar包 解压 > tar zxvf hive-0.13.1-bin.tar.gz 配置mysql * 检查MySQL是否安装:rpm -qa | grep m ...
- 用python爬取QQ空间
好久没写博文了,最近捣鼓了一下python,好像有点上瘾了,感觉python比js厉害好多,但是接触不久,只看了<[大家网]Python基础教程(第2版)[www.TopSage.com]> ...
- SPSS数据分析—多分类Logistic回归模型
前面我们说过二分类Logistic回归模型,但分类变量并不只是二分类一种,还有多分类,本次我们介绍当因变量为多分类时的Logistic回归模型. 多分类Logistic回归模型又分为有序多分类Logi ...
- Unity中Time.deltaTime的含义及其应用
The time in scenes it took to complete the last frame.这是使用此函数的时候给出的提示 一般我们会在设置速度的时候看到这个函数.先写出我对Time. ...
- HAproxy配置文件操作
要求 1. 根据用户输入输出对应的backend下的server信息2. 可添加backend 和sever信息3. 可修改backend 和sever信息4. 可删除backend 和sever信息 ...