当前位置: 首页 > news >正文

你必须知道的EF知识和经验

工欲善其事,必先利其器。

我们使用EF和在很大程度提高了开发速度,不过随之带来的是很多性能低下的写法和生成不太高效的sql。

虽然我们可以使用SQL Server Profiler来监控执行的sql,不过个人觉得实属麻烦,每次需要打开、过滤、清除、关闭。

在这里强烈推荐一个插件MiniProfiler。实时监控页面请求对应执行的sql语句、执行时间。简单、方便、针对性强。

如图:(具体使用和介绍请移步)

数据准备

新建实体:Score(成绩分数表)、Student(学生表)、Teacher(老师表)

后面会给出demo代码下载链接

foreach循环的陷进

1.关于延迟加载

请看上图红框。为什么StudentId有值,而Studet为null?因为使用code first,需要设置导航属性为virtual,才会加载延迟加载数据。

2.关于在循环中访问导航属性的异常处理(接着上面,加上virtual后会报以下异常)

"已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭。"

解决方案:

  • 方案1、设定ConnectionString加上MultipleActiveResultSets=true,但只适用于SQL 2005以后的版本
  • 方案2、或者先读出放置在List中

3.以上两点仅为热身,我们说的陷阱才刚刚开始!

然后我们点击打开MiniProfiler工具(不要被吓到)

解决方案:使用Include显示连接查询(注意:需要手动导入using System.Data.Entity 不然Include只能传表名字符串)。

再看MiniProfiler的监控(瞬间101条sql变成了1条,这其中的性能可想而知。)

AutoMapper工具

上面我们通过Include显示的执行表的连接查询显然是不错的,但还不够。如果我们只需要查询数据的某些字段呢,上面查询所有字段岂不是很浪费内存存储空间和应用程序与数据库数据传输带宽。

我们可以:

对应监控到的sql:

我们看到生成的sql,查询的字段少了很多。只有我们显示列出来字段的和一个StudentId,StudentId用来连接查询条件的。

是的,这样的方式很不错。可是有没有什么更好的方案或方式呢?答案是肯定的。(不然,也不会在这里屁话了。)如果表字段非常多,我们需要使用的字段也非常多,导航属性也非常多的时候,这样的手动映射就显得不那么好看了。那么接下来我们开始介绍使用AutoMapper来完成映射:

http://www.jsqmd.com/news/1105191/

相关文章:

  • 指纹浏览器性能横评:100个窗口同时跑,谁的内存和延迟表现最好?
  • 国密SM4加密模式选择:从ECB风险到GCM最佳实践
  • 为什么你的IDEA永远在“红色感叹号循环”?揭秘被忽略的.project/.idea/.iml三文件权限与编码一致性漏洞
  • AI模型能力评估与发布机制解析:从基准测试到访问控制
  • SMIC 0.18μm工艺下400MHz环形VCO锁相环仿真资源包:含电路图、HTML说明页与实操指引,开箱即跑
  • SIMA:首个端到端自然语言驱动的通用3D交互AI代理
  • Anthropic Zero-Layer:让AI中间层自动归零的生产级架构
  • Mythos能力跃迁:大模型推理深度与跨文档验证的门控式释放
  • 渗透测试工具链实战指南:从信息搜集到后渗透的完整工作流
  • 大语言模型说服力的底层机制与工程化落地
  • Apache HttpClient SSL/TLS配置实战:从证书验证到双向认证
  • 表示工程:用向量方向精准调控大模型语义行为
  • Claude 4.0‘归零层’解析:语义保真度校验环的剥离与重构
  • GPT-4动态稀疏激活:MoE架构下的条件计算革命
  • 大模型MoE架构揭秘:为何仅2%参数被激活
  • 收藏!小白程序员必看:如何避免被AI“外包”思维,掌握核心能力?
  • Claude Managed Agents:会话状态解耦与沙箱安全的工程实践
  • 大模型原生能力崛起:工程补偿层正悄然失效
  • Claude语义压缩层蒸发:从可控推理到结果可信的范式迁移
  • ModTheSpire完全指南:5步解锁《杀戮尖塔》无限模组世界 [特殊字符]
  • 拆解大模型的中立幻觉:四层显影法识别Gen AI偏见
  • 大模型MoE架构原理与工程实践全解析
  • Anthropic Claude 3.5能力跃迁与API分级发布机制解析
  • 修复SSL/TLS弱DH密钥漏洞:Nginx与Apache服务器安全加固实战
  • 基于TPA3128D2与STM32的高保真音频系统设计
  • GPT-4参数量与2%激活率的技术真相:MoE架构深度解析
  • Grok-3技术解析:xAI大模型架构与科研辅助实践
  • OpenSSH 8.7升级与安全加固实战:禁用老旧算法与配置优化
  • STC89C52单片机搭配SIM800 GPRS模块实现温湿度短信上报与远程指令响应(含可烧录Hex及完整Keil工程)
  • AI模型版本命名规范与事实核查指南