/// <summary>
/// EF DAL CURD基类
/// </summary>
/// <typeparam name="T"></typeparam>
public class BaseDAL<T> where T : class, new()
{ /// <summary>
/// 上下文网关
/// </summary>
protected SchoolEntities db = new SchoolEntities(); #region 1.Add /// <summary>
/// 增加一条数据
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
public T AddEntity(T entity)
{ db.Entry<T>(entity).State = EntityState.Added;
// db.Set<T>().Add(entity);此方法同上方法
db.SaveChanges();
return entity;//因为可能要返回自动增长的ID,所以把整个实体返回,否则可以直接返回bool。
}
/// <summary>
/// 同时增加多条数据到一张表(事务处理)
/// </summary>
/// <param name="entitys"></param>
/// <returns></returns>
public bool AddEntity(List<T> entitys)
{
foreach (var entity in entitys)
{
db.Entry<T>(entity).State = EntityState.Added;
}
// entitys.ForEach(c=>db.Entry<T>(c).State = EntityState.Added);//等价于上面的循环
return db.SaveChanges() > ;
}
#endregion #region 2.Modify
/// <summary>
/// 修改一条数据,会修改所有列的值,没有赋值的属性将会被赋予属性类型的默认值**************
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
public bool ModifyEntity(T entity)
{
db.Set<T>().Attach(entity);
db.Entry<T>(entity).State = EntityState.Modified;//将所有属性标记为修改状态
return db.SaveChanges() > ;
}
/// <summary>
/// 修改一条数据,会修改指定列的值
/// </summary>
/// <param name="entity">要修改的实体对象</param>
/// <param name="proNames">要修改的属性名称</param>
/// <returns></returns>
public bool ModifyEntity(T entity, params string[] proNames)
{
db.Set<T>().Attach(entity);
DbEntityEntry<T> dbee = db.Entry<T>(entity);
dbee.State = EntityState.Unchanged;//先将所有属性状态标记为未修改
proNames.ToList().ForEach(c => dbee.Property(c).IsModified = true);//将要修改的属性状态标记为修改
return db.SaveChanges() > ;
}
/// <summary>
/// 根据条件批量修改指定的列********************
/// </summary>
/// <param name="entity"></param>
/// <param name="whereLambds"></param>
/// <param name="proNames"></param>
/// <returns></returns>
public bool ModifyEntity(T entity, Func<T, bool> whereLambds, params string[] proNames)
{
var entitys = db.Set<T>().Where(whereLambds).ToList();
PropertyInfo[] proinfos = entity.GetType().GetProperties();
List<PropertyInfo> list = new List<PropertyInfo>();
foreach (var p in proinfos)
{
if (proNames.Contains(p.Name))
{
list.Add(p);
}
}
entitys.ForEach(c => {
foreach (var p in list)
{
object value = p.GetValue(entity, null);
p.SetValue(c, value, null);
}
});
return db.SaveChanges() > ;
}
#endregion #region 3.Delete /// <summary>
/// 删除一个实体对象
/// </summary>
/// <param name="entity"></param>
/// <returns></returns>
public bool DeleteEntity(T entity)
{
db.Set<T>().Attach(entity);
db.Entry<T>(entity).State = EntityState.Deleted;
return db.SaveChanges() > ;
}
/// <summary>
/// 根据条件批量删除实体对象
/// </summary>
/// <param name="whereLambds"></param>
/// <returns></returns>
public bool DeleteEntityByWhere(Func<T, bool> whereLambds)
{
var data = db.Set<T>().Where<T>(whereLambds).ToList();
return DeleteEntitys(data);
}
/// <summary>
/// 事务批量删除实体对象
/// </summary>
/// <param name="entitys"></param>
/// <returns></returns>
public bool DeleteEntitys(List<T> entitys)
{
foreach (var item in entitys)
{
db.Set<T>().Attach(item);
db.Entry<T>(item).State = EntityState.Deleted;
}
return db.SaveChanges() > ;
} #endregion #region 4.Select
//带条件查询
public IList<T> GetEntitys(Func<T, bool> whereLambds)
{
return db.Set<T>().Where<T>(whereLambds).ToList<T>();
}
//带排序查询
public IList<T> GetEntitys<S>(Func<T, bool> whereLambds, bool isAsc, Func<T, S> orderByLambds)
{
var temp = db.Set<T>().Where<T>(whereLambds);
if (isAsc)
{
return temp.OrderBy<T, S>(orderByLambds).ToList<T>();
}
else
{
return temp.OrderByDescending<T, S>(orderByLambds).ToList<T>();
}
}
//带分页查询
public IList<T> GetPagedEntitys<S>(int pageIndex, int pageSize, out int rows, out int totalPage, Func<T, bool> whereLambds, bool isAsc, Func<T, S> orderByLambds)
{
var temp = db.Set<T>().Where<T>(whereLambds);
rows = temp.Count();
if (rows % pageSize == )
{
totalPage = rows / pageSize;
}
else
{
totalPage = rows / pageSize + ;
}
if (isAsc)
{
temp = temp.OrderBy<T, S>(orderByLambds);
}
else
{
temp = temp.OrderByDescending<T, S>(orderByLambds);
}
temp = temp.Skip<T>(pageSize* (pageIndex - )).Take<T>(pageSize); return temp.ToList<T>();
}
//传统sql结合EF分页实现查询
public IList<T> GetPagedEntitys(int pageIndex, int pageSize, out int rows, out int totalPage, string sql, string where, bool isAsc, string orderKey)
{ sql = sql + " where 1=1 " + where;
sql += " order by " + orderKey;
if (!isAsc)
{
sql += " desc";
}
var temp = db.Database.SqlQuery<T>(sql);
rows = temp.Count();
if (rows % pageSize == )
{
totalPage = rows / pageSize;
}
else
{
totalPage = rows / pageSize + ;
} temp = temp.Skip(pageSize* (pageIndex - )).Take(pageSize);
return temp.ToList<T>(); ; }
#endregion #region 5.显式Tran
/// <summary>
/// 显式执行事务
/// </summary>
/// <param name="dics"></param>
/// <returns></returns>
public int ExeTran(IDictionary<string, DbParameter[]> dics)
{
int result = ;
DbConnection con = ((IObjectContextAdapter)db).ObjectContext.Connection;
using (DbTransaction tran = con.BeginTransaction())
{
try
{
//第一种,传统的执行事务的方法
//db.Database.ExecuteSqlCommand();
// db.Database.SqlQuery();
foreach (var dic in dics)
{
if (dic.Value != null)
{
result += db.Database.ExecuteSqlCommand(dic.Key, dic.Value);
}
else
{
result += db.Database.ExecuteSqlCommand(dic.Key, dic.Value);
} }
//第二种,
// db.UserInfo.Add(entity);
//db.UserInfo.Attach(entity);
//db. tran.Commit();
return result; }
catch (Exception ex)
{ tran.Rollback();
throw ex;
}
finally
{
con.Close();
}
}
}
#endregion
}

EF增删查改基类的更多相关文章

  1. EF增删查改加执行存储过程和sql语句,多种方法汇总

    ActionUrl c = new ActionUrl() { ActionName="test", RequestUrl="/123/123", SubTim ...

  2. EF增删查改(三)------终极版

    1.Add #region 1.1 新增学生信息(定义成Int类型,返回受影响的行数) /// <summary> /// 新增学生信息 /// </summary> /// ...

  3. MVC学习之路(1) EF 增删查改合集

    首先再Model中创建一个类[WMBlogDB] public class WMBlogDB : DbContext { //连接字符串. public WMBlogDB() : base(" ...

  4. Entity Framework(三)---FluentAPI和增删查改

    一.FluentAPI: 1.基本配置: namespace ConsoleApp14.ModelConfig { public class PersonConfig: EntityTypeConfi ...

  5. 3.EF 6.0 Code-First实现增删查改

    原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-entity-framework-5-0-code- ...

  6. 2015.8.2 jdbc实现商品类的增删查改

    在惠普济宁基地进行了两周sql和java的学习,学到很多东西 刚才实现了用jdbc访问数据库对数据库进行操作,是用eclipse写的,过几天移植到NetBeans上,个人还是比较习惯看图形化界面 前几 ...

  7. EF各版本增删查改及执行Sql语句

    自从我开始使用Visual Studio 也已经经历了好几个版本了,而且这中间EF等框架的改变也算是比较多的.本篇文章记录下各个版本EF执行Sql语句和直接进行增删查改操作的区别,方便自己随时切换版本 ...

  8. [课本]JDBC课程6--使用JDBC的DAO模块化--完成数据库的增删查改_工具类JDBCTools四个(Preparedstatement)功能模块的敲定版

    (课本P273-任务九) /**DAO: Data Access Object * 为什么用: 实现功能的模块化,更有利于代码的维护和升级 * 是什么: 访问数据信息的类,包含对数据的CRUD(cre ...

  9. 6.在MVC中使用泛型仓储模式和依赖注入实现增删查改

    原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pat ...

随机推荐

  1. (转)windows 2003 远程桌面关闭 运行程序退出解决

    windows 2003 远程桌面关闭 运行程序退出解决 原文:http://2798996.blog.51cto.com/2788996/503365 情况:远程桌面到2003,运行一个程序,然后关 ...

  2. springboot设置静态资源不拦截的方法

    springboot设置静态资源不拦截的方法 springboot不拦截静态资源需配置如下的类: import org.springframework.context.annotation.Confi ...

  3. MySQL 5.7.21版本sql_mode=only_full_group_by问题

      用到GROUP BY 语句查询时com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Expression #2 of SELECT ...

  4. SPSS学习系列之SPSS Text Analytics是什么?

    不多说,直接上干货! IBM® SPSS® Text Analytics 是一个IBM® SPSS® Modeler 完全集成内插式插件,它采用了先进语言技术和Natural Language Pro ...

  5. Fiddler Web Debugger的代理功能(图文详解)

    不多说,直接上干货! Fiddler的大部分功能都是在其作为本地代理的基础上实现的,如上面介绍的原理图一样,如果想实现数据包截断功能必须要设置为代理,它的代理功能设置比较简单,Fiddler版本2以后 ...

  6. 06-python中的装饰器

    java类中, 有一系列的装饰器, 尤其对文件的操作, python的装饰器比较简单, 直接上代码 #!/usr/bin/env python3 #coding:utf- ''' python的装饰器 ...

  7. Nodejs学习笔记(七)—Node.js + Express 构建网站简单示例

    前言 上一篇学习了一些构建网站会用到的一些知识点:https://www.cnblogs.com/flyingeagle/p/9192936.html 这一篇主要结合前面讲到的知识,去构建一个较为完整 ...

  8. SpringBoot入门 (一) HelloWorld

    一 什么是springboot springboot是一个全新的框架,它设计的目的简化spring项目的初始环境的搭建和开发,主要有以下几个特点: 1.简化初始配置 ,可与主流框架集成: 2.内置Se ...

  9. layer相关使用

    父子页面传参数 转自:https://blog.csdn.net/babyxue/article/details/76854106 1.父页面打开子页面并向子页面传参数 function setCho ...

  10. [PY3]——Queue

    Queue class Queue(builtins.object) __init__(self, maxsize=0) empty(self) full(self) get(self, block= ...