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>
        ///     删除所有符合特定表达式的数据
        /// </summary>
        /// <param name="predicate"> 查询条件谓语表达式 </param>
        /// <returns> 操作影响的行数 </returns>
        public virtual int Delete(Expression<Func<TEntity, bool>> predicate)
        {
            return Entities.Delete(predicate);
        }

        /// <summary>
        /// 修改操作
        /// </summary>
        /// <param name="fun1">查询条件-谓语表达式</param>
        /// <param name="fun2">实体-谓语表达式</param>
        /// <returns>操作影响的行数</returns>
        public virtual int Update(Expression<Func<TEntity, bool>> fun1, Expression<Func<TEntity, TEntity>> fun2)
        {
            return Entities.Update(fun1, fun2);
        }

 

转载于:https://www.cnblogs.com/AntonWang/p/3727500.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
entityframework.dll是Entity Framework的核心文件之一,用于在Windows Server 2022上进行数据库访问和管理。Entity Framework是Microsoft开发的一种面向对象的关系型数据库访问技术,它提供了一种便捷的方式来操作数据库,减少了开发人员编写冗长SQL语句的工作量。entityframework.dll文件包含了Entity Framework的一些核心功能和API接口,通过该文件可以实现对数据库的连接、数据的读写、以及数据模型的管理。 在Windows Server 2022上使用entityframework.dll可以实现对SQL Server、MySQL、SQLite等多种数据库的访问和操作。借助Entity Framework的强大功能,开发人员可以轻松地进行数据库编程,提高了开发效率和代码的可维护性。同时,Entity Framework还提供了一种Code First的开发模式,允许开发人员直接通过编写C#或VB.NET代码来定义数据库模型,然后由Entity Framework自动生成相应的数据库结构,极大地简化了数据库设计与开发的过程。 在Windows Server 2022上,使用entityframework.dll可以充分发挥Entity Framework的优势,使得应用程序能够高效、稳定地访问数据库,实现数据的持久化存储,并且可以通过Entity Framework提供的Linq查询语言进行数据查询和筛选,极大地提升了对数据库的操作和管理的便捷性。因此,在Win2022平台上使用entityframework.dll对于开发数据库应用来说是非常重要和有益的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值