一、EF简言
EF是ORM框架的一种,ORM是Object Relational Mapping的缩写,即对象关系映射。通过EF可以把对象模型表示的对象映射到基于S Q L 的关系模型数据库结构中去。这样,我们在具体的操作实体对象的时候,就不需要再去和复杂的 SQ L 语句打交道,只需简单的操作实体对象的属性和方法。
据我所知,有两种使用EF 的模式:
1.code first.通过编写C#代码,引用EF,然后把C#的类,转化为数据库的表。可以通过给类中的属性设置特性来,设置数据库表中字段的属性。//可能我不会用,觉得不好用。理由:如果后续需要增加某个表的字段,需要NUGET的数据迁移,还需要掌握C#中对类设置个个特性。在代码中编辑设计数据库?!,我只需要操纵SQLSERVER而已,设置默认值,主键,自增长等等。
2.model first。这是我使用的。可以使用VS中的ADO实体数据模型+T4模版+泛型,完成底层的搭建。这个是通用的,大部分应该都可以用。
二、部分代码
public interface IBaseDal<T> where T : class, new()//限制只能是类名,并且有无参构造函数的实现
{
IQueryable<T> LoadEntities(System.Linq.Expressions.Expression<Func<T, bool>> whereLambda);
IQueryable<T> LoadPageEntities<s>(int pageIndex, int pageSize, out int totalCount, System.Linq.Expressions.Expression<Func<T, bool>> whereLambda, System.Linq.Expressions.Expression<Func<T, s>> orderbyLambda, bool isAsc);
//<s>lambda表达式中的返回值
bool DeleteEntity(T entity);
bool EditEntity(T entity);
T AddEntity(T entity);
}
IQueryable:实现了延迟加载的功能。其实就是现将查询条件储存起来,然后再执行。
IEnumable:立即执行。