Lv.的博客

EntityFramework.Extended扩展用法

 

 

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>        ///     删除所有符合特定表达式的数据     
posted @   Avatarx  阅读(489)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
历史上的今天:
2014-06-07 FTP服务器简易有效的访问方法
点击右上角即可分享
微信分享提示