Entity Framework Extended Library (EF扩展类库,支持批量更新、删除、合并多个查询等)…

Entity Framework Extended Library (EF扩展类库,支持批量更新、删除、合并多个查询等)…

今天乍一看,园子里居然没有关于这个类库的文章,实在是意外毕竟已经有很多介绍EF使用的文章了。

E文好的可以直接看https://github.com/loresoft/EntityFramework.Extended

也可以在nuget上直接安装这个包,它的说明有点过时了,最新版本已经改用对IQueryable<T>的扩展,而不是DbSet<T>(已经标记为弃用),所以跟我一样有隔离癖好的就可以大胆使用了。下面介绍如何批量删除、更新、查询。

批量删除

本来我们需要这样删除

?
//EF原生的删除需要先取出entity然后remove
context.Remove(context.Users.First(u=>u.Key==xxx);
//如果要删除更多
foreach
(var user
in
 
context.Users.Where(u => u.FirstName ==
"firstname"
).ToList())
{
context.Remove(user);
}

本来一句sql可以解决的问题,变得复杂了。

 使用ORM是为了跟sql尽量的解耦,并且能在编译时检查出更多的错误,但是上面的写法让人堵的慌,如果你也有这种感觉下面的写法是不是就是你脑子里想要的东西呢。


----引用EF Extend Libary后删除只需要一次就完成了,效率高了很多,也不需要太多的连接资源,使用更方便了
?
//delete all users where FirstName matches
context.Users.Delete(u => u.FirstName ==
"firstname"
);
//当然如果我这样写也可以
context.Users.Where(...).Delete();

当第一次看到EF EL的时候就被这种写法吸引住了,这不就是我们一直找的东西么。

批量更新

?
//批量更新用户名中包含大写J的用户设置工资为999
context.Users.Update(
    
u => u.Name.Contans(
"J"
),
    
u2 =>
new
 
User {Salary = 999});
 
//第一个参数也可以传入已经有的IQuaryable的参数如下
var users = context.Users.Where(u => u.FirstName ==
"firstname"
);
context.Users.Update(users, u =>
new
 
User {FirstName =
"newfirstname"
});<br><br>
//当然了我最喜欢的还是这样的写法<br>context.Users.Where(u => u.FirstName == "firstname").Update(u=>new User{FirstName = "newfirstname"})

  是不是更喜欢这个扩展库了?我是爱不释手了,可惜现在才开始用。

 批量查询

 其实现在的查询已经很棒了,默认的延迟查询都能满足基本需求,但是有时候总希望更极致一点,比如现有的查询无法满足分页这个顽固的需求。

?
//看看EF EL怎么解决
// 复用的查询
var q = db.Tasks.Where(t => t.Priority == 2);
// 获取总数
var q1 = q.FutureCount();
// 获取分页的数据
var q2 = q.Skip(pageIndex).Take(pageSize).Future();
 
// 这里会触发上面所有Future函数中的查询包装到一个连接中执行
int
 
total = q1.Value;
//因为已经得到结果了,这里不会再次查询
var tasks = q2.ToList();

  

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/110106.html原文链接:https://javaforall.net

(0)
上一篇 2021年8月24日 下午1:00
下一篇 2021年8月24日 下午2:00


相关推荐

  • 智谱AutoClaw一键部署指南:集成Pony-Alpha-2,搭建支持50+技能的本地Agent

    智谱AutoClaw一键部署指南:集成Pony-Alpha-2,搭建支持50+技能的本地Agent

    2026年3月12日
    2
  • 空格html代码快捷键,html的空格代码怎么写?教你如何使用空格nbsp代码[通俗易懂]

    空格html代码快捷键,html的空格代码怎么写?教你如何使用空格nbsp代码[通俗易懂]本篇文章为大家介绍的是HTML的空格代码的写法,“&nbsp;”代码的用法,还有几种空格方式的解释,都在文章中,现在开始往下看吧。首先,我们知道这HTML网页中插入多个空格间隔是需要特殊字符编码的。如果是直接敲入多个空格键的话,虽然看似代码中有了多个空格效果,但其实在浏览器中还是只有1个空格间隔位置的。接下来教大家如果输入html空格字符的话,多个空格字符是如何输入的?我们采用直接复制空格…

    2026年2月18日
    4
  • JAVA文件传输程序

    JAVA文件传输程序第 3 章 nbsp nbsp nbsp nbsp nbsp 设计文档 3 1 nbsp nbsp nbsp nbsp nbsp nbsp nbsp 任务概述 nbsp nbsp nbsp nbsp nbsp nbsp nbsp 本项任务要开发一款 P2P 文件传输软件 该软件可以在局域网和互连上使用 具有文件传输 断点续传 多线程连接等功能 3 1 1 nbsp nbsp nbsp nbsp nbsp nbsp 开发背景 nbsp nbsp nbsp nbsp nbsp nbsp nbsp 随着网络的普及 在网络中交换信息 特别是文件成为使用网络时经常性工作 现有的文件传输工具如 MSN 等 主要功能是作为即时通讯工具使用

    2026年3月18日
    2
  • pycharm格式化代码 快捷键

    pycharm格式化代码 快捷键ctrl alt L 一常用快捷键编辑类 Ctrl D 复制选定的区域或行 Ctrl Y 删除选定的行 Ctrl Alt L 代码格式化 Ctrl Alt O 优化导入 去掉用不到的包导入 Ctrl 鼠标简介 进入代码定义 Ctrl 行注释 取消

    2026年3月20日
    1
  • Linux安装yum教程

    Linux安装yum教程Linux 安装 yum 标签 教程 1 检查是否安装查看是否安装 yum 若是安装了还有那些包 rpm qa grepyum2 删除原有的 yumrpm aq grepyum xargsrpm e nodeps3 专门存放下载的路径 cd usr local src4 下载安装依赖包 py 下载地址 进度条 100 表示已完成 wgethttp mirrors

    2026年3月18日
    2
  • IMEI/ESN/MEID号码「建议收藏」

    IMEI/ESN/MEID号码「建议收藏」IMEI/ESN/MEID号码1、引言   正规的手机产品,在手机软件里面、手机背面以及手机的包装盒子上都是标识有IMEI号码或MEID号码的,这三个号码完全一致的话,才表示这个产品是由这个正规厂家生产的。其中IMEI号码是用于GSM和WCDMA制式的手机,而MEID号码是用于CDMA制式的手机。手机在国内进行入网测试时,是需要提供真实的IMEI或MEID,出口海外的手机也是需要

    2022年8月30日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号