EF中使用泛型

    

     新项目由于使用了EF,感觉写了很多重复代码,为什么不用泛型呢,带着这个疑问才有了这篇学习笔记。以前也没有做过用EF的项目,以下内容自学的。

     使用EF来进行数据查询的确很方便,但是代码写得多了以后你会发现很多工作都是重复性很强的工作,比如查询数据并返回列表.如果是小型项目,实体类在5个以内,使用常规的查询方法尚可忍受,但是实体类多了,老是重复同一方法,很快你就会发疯----这不但很麻烦,也没有必要!

怎么办呢,使用泛型是解决这一问题的重要途径,通过研究,ObjectContext的CreateObjectSet方法就是解决这一问题的良方.

在MSDN里查阅到关于ObjectContext.CreateObjectSet 方法的相关描述是这样的:

公共方法CreateObjectSet<TEntity>() 创建新的 ObjectSet<TEntity> 实例,该实例用于查询、添加、修改和删除指定实体类型的对象。

公共方法CreateObjectSet<TEntity>(String) 创建新的 ObjectSet<TEntity> 实例,该实例用于查询、添加、修改和删除具有指定类型和指定实体集名称的对象。

从方法的说明来看,这是一个全能的方法,GURD样样精通,下面就使用它来实现泛型的数据查询方法.

 

 

  获取数据集

public static List<T> GetListOf<T>(Expression<Func<T, bool>> expression) where T:class
      {
          ProductsEntities _context = new ProductsEntities();          
          return _context.CreateObjectSet<T>().Where(expression).ToList();        
      }

添加

public static void AddNewData<T>(T t) where T : class
      {
          using (var ctx = new ProductsEntities())
          {
              ctx.CreateObjectSet<T>().AddObject(t);
              ctx.SaveChanges();
          }
      }



现在发现EF 确实很好用!

 

 

 

 

 

 

 

 

 

 

 

 

转载于:https://www.cnblogs.com/fjzhang/archive/2012/05/17/2505787.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值