EntityFramework.Extended扩展用法

本文介绍了一个基于Entity Framework的扩展库EntityFramework.Extended的使用方法,包括如何安装、配置数据上下文以及实现局部更新和删除等功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

 

EntityFramework.Extended是一个基于EntityFramework框架 IQueryable类型的扩展方法,包括Update、Delete。

它的优点就是 修改删除操作不仅仅有Id一个条件,可以有过个条件;

做修改时不仅可以传入整个实体类型,也可以根据条件只传入需要改变的局部字段内容。

1.Nuget程序包管理 搜索并下载程序集

2.创建一个数据上下文

/  // <summary>    /// 数据上下文    /// </summary>    public class MyDbContext:DbContext    {        #region 构造函数        /// <summary>        ///     初始化一个 使用连接名称为“default”的数据访问上下文类 的新实例        /// </summary>        public MyDbContext()            : base("SqlServer") { }        /// <summary>        /// 初始化一个 使用指定数据连接名称或连接串 的数据访问上下文类 的新实例        /// </summary>        public SchoolDbContext(string nameOrConnectionString)            : base(nameOrConnectionString) {  }        #endregion                #region 属性        public DbSet<Member> Member { get; set; }        #endregion    }


3.调用方法

前提需要引用命名空间

using EntityFramework.Extensions;

请注意他是 IQueryable的扩展方法;

修改局部字段内容:

        public bool ModifyName(int memberId,string name,string newName)        {            using (MyDbContext context = new MyDbContext())            {                int state = context.Member.Update(                    m => m.Id==memberId && m.Name == newName,   //修改条件                    m => new Member { Name = newName });        //只修改Name                return state > 0 ? true : false;            }        }        #endregion


删除操作:

public bool Delete(int memberId)        {            using (MyDbContext context = new MyDbContext())            {                int state = context.Member.Delete(                    m => m.Id == memberId //修改条件                    );                return state > 0 ? true : false;            }        }

如果把它封装到Repository仓储操作类里起来更方便了

        /// <summary>        ///     获取 当前实体的查询数据集        /// </summary>        public virtual IQueryable<TEntity> Entities        {            get { return EFContext.Set<TEntity>(); }        }

 

        /// <summary>        ///     删除所有符合特定表达式的数据     

转载于:https://www.cnblogs.com/lvdongjie/p/5566169.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值