EF 底层封装方法(供参考)
闲暇之余,整理了一下EF底层的一些基础方法,供查看,只有接口,具体实现需要你们自己写了。
建议:接口的实现定义为虚方法,当父类的方法不满住子类需求时,可以重写此方法
此接口都为公用方法,基本上满足小系统的实际开发需求,如果你觉得满足不了你,可以扩展此接口。
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Entity;
using System.Data.SqlClient;
using System.Linq;
using System.Linq.Expressions;
using System.Text;
using System.Threading.Tasks; namespace Basic.IRepository
{
public interface ICommonRepository<T> where T : class, new()
{
#region Other /// <summary>
/// 确定序列中的任何元素是否都满足条件
/// </summary>
/// <param name="whereLambda"></param>
/// <returns></returns>
bool Any(Expression<Func<T, bool>> whereLambda); /// <summary>
/// 返回序列中元素的数量
/// </summary>
/// <param name="whereLambda"></param>
/// <returns></returns>
int Count(Expression<Func<T, bool>> whereLambda); /// <summary>
/// 返回最大值
/// </summary>
/// <typeparam name="Tkey"></typeparam>
/// <param name="predicate"></param>
/// <param name="selector"></param>
/// <returns></returns>
Tkey Max<Tkey>(Expression<Func<T, bool>> whereLambda, Func<T, Tkey> selector); /// <summary>
/// 返回分组查询的数量
/// </summary>
/// <typeparam name="TKey"></typeparam>
/// <param name="whereLambda"></param>
/// <param name="groupBy"></param>
/// <returns></returns>
IDictionary<TKey, int> Count<TKey>(Expression<Func<T, bool>> whereLambda, Expression<Func<T, TKey>> groupBy); /// <summary>
/// 分组求和
/// </summary>
/// <typeparam name="TKey"></typeparam>
/// <param name="whereLambda"></param>
/// <param name="groupBy"></param>
/// <param name="selector"></param>
/// <returns></returns>
IDictionary<TKey, decimal> Sum<TKey>(Expression<Func<T, bool>> whereLambda, Expression<Func<T, TKey>> groupBy, Func<T, decimal> selector); /// <summary>
/// 获取表名
/// </summary>
/// <param name="type"></param>
/// <returns></returns>
string GetTableName(Type type); /// <summary>
/// 得到SqlServer 表相关信息(字段名,类型.....)
/// </summary>
/// <param name="tableName"></param>
/// <returns></returns>
IEnumerable<SqlServerColumnModel> GetSqlServerTableOrViewColumns(string tableName); /// <summary>
/// 得到MySql 表相关信息(字段名,类型.....)
/// </summary>
/// <param name="tableName"></param>
/// <returns></returns>
IEnumerable<MySqlColumnModel> GetMySqlTableOrViewColumns(string tableName); #endregion #region Insert
/// <summary>
/// 添加
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
bool Add(T model); /// <summary>
/// 批量添加
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
bool AddRange(IEnumerable<T> model); /// <summary>
/// 批量添加 生成Sql执行
/// </summary>
/// <param name="model"></param>
/// <param name="clearHistoryData"></param>
void BulkInsertToSql(IEnumerable<T> model, bool clearHistoryData = false); /// <summary>
/// 批量添加 SqlServer
/// 通过 SqlBulkCopy 实现
/// </summary>
/// <param name="model"></param>
/// <param name="clearHistoryData"></param>
void BulkInsertSqlServer(IEnumerable<T> model, bool clearHistoryData = false); /// <summary>
/// 批量添加 MySql
/// 通过 MySqlBulkLoader 实现
/// </summary>
/// <param name="model"></param>
/// <param name="clearHistoryData"></param>
int BulkInsertMySql(IEnumerable<T> model, string csvPath, bool clearHistoryData = false); #endregion #region Delete /// <summary>
/// 按主键删除
/// </summary>
/// <param name="id"></param>
bool DeleteById(dynamic id); /// <summary>
/// 删除
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
bool Delete(T model); /// <summary>
/// 按条件删除
/// </summary>
/// <param name="id"></param>
bool DeleteByWhere(Expression<Func<T, bool>> whereLambda); /// <summary>
/// 批量删除
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
bool DeleteRange(IEnumerable<T> model); /// <summary>
/// 批量删除
/// </summary>
/// <param name="where">条件:{Name="张三",性别="男"}</param>
/// <returns></returns>
bool BulkDelete(object where); /// <summary>
/// 批量删除
/// </summary>
/// <param name="where">条件:{Name="张三",性别="男"}</param>
/// <param name="notWhere">过滤的条件:{Name="张三",年龄="18"}</param>
/// <returns></returns>
bool BulkDelete(object where,object notWhere); #endregion #region Update
/// <summary>
/// 更新
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
bool Update(T model); /// <summary>
/// 批量更新
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
bool UpdateRange(IEnumerable<T> models); /// <summary>
/// 批量更新,不带条件
/// </summary>
/// <param name="set">修改的数据:{Name="张三",年龄=22}</param>
/// <returns></returns>
bool BulkUpdate(object set); /// <summary>
/// 批量更新,带条件
/// </summary>
/// <param name="set">修改的数据:{Name="张三",年龄=22}</param>
/// <param name="where">条件:{Name="张三",性别="男"}</param>
/// <returns></returns>
bool BulkUpdate(object set, object where); #endregion #region Select /// <summary>
/// 按主键查询
/// </summary>
/// <param name="id">主键</param>
/// <returns></returns>
T Find(dynamic id); /// <summary>
/// 通过id查看是否存在
/// </summary>
/// <param name="id">主键</param>
/// <returns></returns>
bool IsExist(dynamic id); /// <summary>
/// 返回序列中的第一个元素
/// </summary>
/// <param name="whereLambda">条件</param>
/// <returns></returns>
T FirstOrDefault(Expression<Func<T, bool>> whereLambda); /// <summary>
/// 获取数据
/// </summary>
/// <typeparam name="TObj">排序类型</typeparam>
/// <param name="whereLambda">条件</param>
/// <param name="orderBy">排序字段</param>
/// <param name="isASC">是否升序</param>
/// <returns></returns>
IEnumerable<T> Find<TObj>(Expression<Func<T, bool>> whereLambda, Expression<Func<T, TObj>> orderBy, bool isASC = true); /// <summary>
/// 获取数据
/// </summary>
/// <typeparam name="TKey">排序类型 1</typeparam>
/// <typeparam name="TObj">排序类型 2</typeparam>
/// <param name="whereLambda">条件</param>
/// <param name="orderBy">排序字段 1</param>
/// <param name="thenBy">排序字段 2</param>
/// <param name="isASC">是否升序</param>
/// <returns></returns>
IEnumerable<T> Find<TKey,TObj>(Expression<Func<T, bool>> whereLambda, Expression<Func<T, TKey>> orderBy, Expression<Func<T, TObj>> thenBy, bool isASC = true); /// <summary>
/// 分页查询 生成SQL执行 SQLSERVER
/// </summary>
/// <param name="name">表名/视图</param>
/// <param name="where">条件 name='Jamel' and age = 18</param>
/// <param name="pageIndex">页码</param>
/// <param name="pageSize">数量</param>
/// <param name="orderBy">排序字段</param>
/// <param name="isASC">是否升序</param>
/// <returns></returns>
IEnumerable<T> PagerToSqlServer(string name, string where, int pageIndex, int pageSize, object orderBy, bool isASC = true); /// <summary>
/// 分页查询 生成SQL执行 MYSQL
/// </summary>
/// <param name="name">表名/视图</param>
/// <param name="where">条件 name='Jamel' and age = 18</param>
/// <param name="pageIndex">页码</param>
/// <param name="pageSize">数量</param>
/// <param name="orderBy">排序字段</param>
/// <param name="isASC">是否升序</param>
/// <returns></returns>
IEnumerable<T> PagerToMySql(string name, string where, int pageIndex, int pageSize, object orderBy, bool isASC = true); /// <summary>
/// 分页查询
/// </summary>
/// <typeparam name="TObj">排序类型</typeparam>
/// <param name="whereLambda">条件</param>
/// <param name="orderBy">排序字段</param>
/// <param name="pageIndex">页码</param>
/// <param name="pageSize">数量</param>
/// <param name="isASC">是否升序</param>
/// <returns></returns>
IEnumerable<T> Pager<TObj>(Expression<Func<T, bool>> whereLambda, Expression<Func<T, TObj>> orderBy, int pageIndex,int pageSize, bool isASC = true); /// <summary>
/// 分页查询
/// </summary>
/// <typeparam name="TKey">排序类型 1</typeparam>
/// <typeparam name="TObj">排序类型 2</typeparam>
/// <param name="whereLambda">条件</param>
/// <param name="orderBy">排序字段 1</param>
/// <param name="thenBy">排序字段 2</param>
/// <param name="pageIndex">页码</param>
/// <param name="pageSize">数量</param>
/// <param name="isASC">是否升序</param>
/// <returns></returns>
IEnumerable<T> Pager<TKey, TObj>(Expression<Func<T, bool>> whereLambda, Expression<Func<T, TKey>> orderBy, Expression<Func<T, TObj>> thenBy, int pageIndex, int pageSize, bool isASC = true); #endregion #region Proc /// <summary>
/// 执行存储过程或自定义sql语句--返回集合(自定义返回类型)
/// SqlServer: exec getActionUrlId @name,@ID
/// MySql: call getActionUrlId(@name,@ID)
/// </summary>
/// <param name="sql">sql语句或存储过程</param>
/// <param name="parms">参数 new SqlParameter("@name","Jamel")</param>
/// <returns></returns>
IEnumerable<T> SqlQuery(string sql, IEnumerable<SqlParameter> parms); /// <summary>
/// 自定义语句和存储过程的增删改--返回影响的行数
/// SqlServer: exec getActionUrlId @name,@ID
/// MySql: call getActionUrlId(@name,@ID)
/// </summary>
/// <param name="sql">sql语句或存储过程</param>
/// <param name="parms">参数 new SqlParameter("@name","Jamel")</param>
/// <returns></returns>
int ExecuteSqlCommand(string sql, IEnumerable<SqlParameter> parms); #endregion }
}
EF 底层封装方法(供参考)的更多相关文章
- EF Core 封装方法Expression<Func<TObject, bool>>与Func<TObject, bool>区别
unc<TObject, bool>是委托(delegate) Expression<Func<TObject, bool>>是表达式 Expression编译后就 ...
- EF 底层基础方法
1 using System; 2 using System.Data; 3 using System.Collections.Generic; 4 using System.Data.Entity; ...
- EF封装类 增加版,增加从缓存中查找数据方法,供参考!
EF封装类 增加版,增加从缓存中查找数据方法,供参考! 这个类是抽象类,我这里增加了需要子类验证的方法ValidateEntity,方便扩展,若想直接使用该类,可以将该类更改成静态类,里面所有的方法都 ...
- EF封装类,供参考!
以下是我对EF DB FIRST 生成的ObjectContext类进行封装,代码如下,供参考学习: using System; using System.Collections.Generic; u ...
- Unity上一页下一页切换功能实现源码(仅供参考)
在做项目时我们有时需要实现切换上一页下一页图片,切换上一首下一首歌曲等等类似的功能.这里写了个简单的实现源码(仅供参考),要是有更好的方法欢迎提出来,共同进步~ 以切换上一页下一页图片为例: usin ...
- 【SSM 7】Mybatis底层封装思路
一.基本概述 在前面的博客中介绍到Mybatis的逆向生成工具,为我们生成了每个实体的基本增删改查的代码,那么每个实体都是那么多的代码,我们很容易的发现,有很大的相似性.对于这部分代码,应该予以抽象封 ...
- NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中
以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...
- 为mutable类型的容器(array,set等)添加kvo,有点麻烦,供参考和了解下吧
http://blog.csdn.net/caryaliu/article/details/49284185 需要在被观察的属性所在的类里面实现一些方法,对开发者不友好,一般不建议使用,这里mark一 ...
- 改善EF代码的方法(下)
本节,我们将介绍一些改善EF代码的方法,包括编译查询.存储模型视图以及冲突处理等内容. > CompiledQuery 提供对查询的编译和缓存以供重新使用.当相同的查询需要执行很多遍的时候,那么 ...
随机推荐
- kubernetes实战之运行aspnetcore webapi微服务 - kubernetes
1.预备工作 unbuntu 16.04 or above docker for linux kubernetes for linux 集群环境 2.使用vs2017创建一个web api应用程序,并 ...
- java的poi技术读取和导入Excel实例
本篇文章主要介绍了java的poi技术读取和导入Excel实例,报表输出是Java应用开发中经常涉及的内容,有需要的可以了解一下. 报表输出是Java应用开发中经常涉及的内容,而一般的报表往往缺乏通用 ...
- BASE64编码原理分析脚本实现及逆向案例
在互联网中的每一刻,你可能都在享受着Base64带来的便捷,但对于Base64的基础原理你又了解多少?今天小编带大家了解一下Base64编码原理分析脚本实现及逆向案例的相关内容. 01编码由来 数 ...
- 清除过期日志的py脚本
本篇和大家分享的是一个清除过期日志的python脚本,年后第二篇希望对大家有帮助: 该python脚本创建的由来 代码及分析 crontab定时任务 该python脚本创建的由来 此由来,是在过年假期 ...
- Java注解(Annotation):请不要小看我!
Java注解是一系列元数据,它提供数据用来解释程序代码,但是注解并非是所解释的代码本身的一部分.注解对于代码的运行效果没有直接影响. 网络上对注解的解释过于严肃.刻板,这并不是我喜欢的风格.尽管这样的 ...
- 网络协议 16 - DNS 协议:网络世界的地址簿
[前五篇]系列文章传送门: 网络协议 11 - Socket 编程(下):眼见为实耳听为虚 网络协议 12 - HTTP 协议:常用而不简单 网络协议 13 - HTTPS 协议:加密路上无尽头 网络 ...
- 合肥.NET技术社区首次线下聚会全程回顾【多图】
2019年3月16日对于合肥.NET来说是一个特别的日子,因为这是合肥.NET技术社区首次非正式线下聚会!这次聚会受场地限制(毕竟是聚餐的形式),即使换成了小椅子后,最多也只能容纳24个人,所以还有一 ...
- 总结http get和post的区别
这个问题几乎面试的时候都会问到,是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎. 什么是http? get.post常见的区别 ge ...
- Flink从入门到放弃(入门篇3)-DataSetAPI
戳更多文章: 1-Flink入门 2-本地环境搭建&构建第一个Flink应用 3-DataSet API 4-DataSteam API 5-集群部署 6-分布式缓存 7-重启策略 8-Fli ...
- Docker核心实现技术(命名空间&控制组&联合文件系统&Linux网络虚拟化支持)
作为一种容器虚拟化技术,Docker深度应用了操作系统的多项底层支持技术. 早期版本的Docker是基于已经成熟的Linux Container(LXC)技术实现的.自Docker 0.9版本起,Do ...