EfCore3的OwnedType会导致Sql效率问题
最近主导了旗下某核心项目升级到EfCore3
由于之前Core2升级时候也踩过不少的坑很多东西都有规划和准备,整体上还是没出太大问题
但是最近突然发现efcore对于使用了ownedType的生成语句有问题
查找了一下资料发现已经有人在efcore的github上开了issus了,并且还讨论的蛮多的了
https://github.com/dotnet/efcore/issues/18299
鉴于很多人看到一堆E文后会直接放弃,下面我简单阐述下这个问题
EfCore自2.0的时候引入了一个叫OwnedType的特性,是用于完善之前EfCore1.x相比于Ef6使其少了的ComplexType特性
正常来说我们用Ef的时候是一个类映射到一个表,但是有时候某些表字段过多的情况下,我们可能会想整理下把一个表里某些信息放到一个子类里,但是其他信息还是在主类
形如
class Order
{
public int Id { get; set; }
public string Title { get; set; }
public Address Address { get; set; }
} class Address
{
public string Street { get; set; }
public string City { get; set; }
}
然后DbContext里配置下
modelBuilder.Entity<Order>().OwnsOne(x => x.Address);
这种情况下最理想生成的语句应该是类似
select Id,Title,Street,City from Orders
这个样子的形式才对,然后EfCore内部再通过自己映射的形式把后面4个字段映射到Author类里的Address这个类里
但是在EfCore3里他生成的语句是形如
SELECT o."Id", o."Title", t."Id", t."Address_City", t."Address_Street"
FROM "Orders" AS o
LEFT JOIN (
SELECT o0."Id", o0."Address_City", o0."Address_Street", o1."Id" AS "Id0"
FROM "Orders" AS o0
INNER JOIN "Orders" AS o1 ON o0."Id" = o1."Id"
WHERE (o0."Address_Street" IS NOT NULL) OR (o0."Address_City" IS NOT NULL)
) AS t ON o."Id" = t."Id"
WHERE (t."Id" IS NULL)
尽管严格来说这个并不影响逻辑,但是这样子join的话对Sql的性能和效率有挺不好的负面影响
就那个issus里也有人做了测试,结果下图

纵坐标是每秒执行的查询数(简单理解为并发数吧)
横坐标是表里有多少数据
可以看到表的数据量上升之后使用了OwnedType的EfCore3会出现显著下滑(自己join自己多了)
接下来就是一个好消息和一个坏消息了
好消息是EfCore那边认可了这个问题然后当前EfCore 5 preview-3修复了这个问题
坏消息是至少目前确认这个修复不会合并到EfCore3.1.x(后期会不会有变数不清楚)
感觉这个蛮坑的,一般公司用的话都会是优先选用LTS,而当前的LTS就是3.1
而接下来的NetCore5(含EfCore5)并不是LTS所以对于公司组织的线上采用率应该会相对较低
那难道修复这个问题还要等一个目前还没规划的NetCore5.1?那是不是要等的有点儿太久了
最后,如果有升级EfCore3的且用了OwnedType(相当于Ef6时期的ComplexType)请谨慎评估下这个问题对你可能造成的影响
毕竟目前看起来,降级回去不大可能,烧香保佑下fix path能到3.1.x要么就只能指望Core5.1了
EfCore3的OwnedType会导致Sql效率问题的更多相关文章
- 【转】导致SQL执行慢的原因
索引对大数据的查询速度的提升是非常大的,Explain可以帮你分析SQL语句是否用到相关索引. 索引类似大学图书馆建书目索引,可以提高数据检索的效率,降低数据库的IO成本.MySQL在300万条记录左 ...
- 导致SQL执行慢的原因
索引对大数据的查询速度的提升是非常大的,Explain可以帮你分析SQL语句是否用到相关索引. 索引类似大学图书馆建书目索引,可以提高数据检索的效率,降低数据库的IO成本.MySQL在300万条记录左 ...
- [MySQL优化] -- 如何查找SQL效率地下的原因
[MySQL优化] -- 如何查找SQL效率地下的原因 来源: ChinaUnix博客 日期: 2009.07.20 16:12 (共有条评论) 我要评论 查询到效率低的 SQL 语句 ...
- 存储过程为什么比sql效率高
对于存储过程为什么比sql效率高的原因有4点 第一就是使用存储过程允许组建式编成, 二是可以对程序进行编译,
- 最新版SEMCMS_PHP_3.5 过滤不严导致sql注入
一.漏洞分析 在分析过程中看到网上已经有人发现semcms V2.4存在过滤不严导致sql注入的漏洞,不知道咋还没改,而且最新版过滤的关键字更少了. 首先查看首页文件index.php的代码 < ...
- 服务器重启可能会导致SQL Server中部分数据库变为single user mode
今天检查公司生产服务器的SQL Server数据库,惊讶的发现有三个生产数据库变为了single user mode.奇怪的是没有任何人和程序执行过SQL语句将这三个数据库设置为single user ...
- Drupal V7.3.1 框架处理不当导致SQL注入
这个漏洞本是2014年时候被人发现的,本着学习的目的,我来做个详细的分析.漏洞虽然很早了,新版的Drupal甚至已经改变了框架的组织方式.但是丝毫不影响对于漏洞的分析.这是一个经典的使用PDO,但是处 ...
- 修改Windows帐户密码,导致Sql Server 2000无法启动
修改Windows帐户密码,导致Sql Server 2000无法启动. --现象以管理员或同等权限用户登录 Windows XP,建立 Sql Server 2000 数据库.之后,在修改此 Win ...
- 12.1.0.2自适应特性导致SQL性能下降
背景介绍 在升级到12.1.0.2.0数据库版本后,在使用12c中引入的自适应特性默认配置的情况下,可能引起SQL性能的下降. 问题现象升级到12.1.0.2.0后,SQL语句性能可能出现下降. 影响 ...
随机推荐
- linux系统jdk安装
1.软件包下载:官网 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html下载linu ...
- Java 的各种内部类、Lambda表达式
内部类 内部类是指在一个外部类的内部再定义一个类.内部类的出现,再次打破了Java单继承的局限性. 内部类可以是静态 static 的,也可用 public,default,protected 和 p ...
- C#开发PACS医学影像处理系统(九):序列控件与拖拽
1.先看结构: 创建WPF用户控件:YourTab 创建WPF用户控件:YourItem 创建选项卡时循环添加item,并设置序列缩略图到控件和异步下载的进度条, 1个病人1个或多个Study检查,1 ...
- [LeetCode]64. 最小路径和(DP)
题目 给定一个无序的整数数组,找到其中最长上升子序列的长度. 示例: 输入: [10,9,2,5,3,7,101,18] 输出: 4 解释: 最长的上升子序列是 [2,3,7,101],它的长度是 4 ...
- 【漏洞复现篇】CVE-2020-1472-微软NetLogon权限提升-手把手教学-简单域环境搭建与Exp执行
一.漏洞简介 NetLogon 远程协议是一种在 Windows 域控上使用的 RPC 接口,被用于各种与用户和机器认证相关的任务.最常用于让用户使用 NTLM 协议登录服务器,也用于 NTP 响应认
- 关于取整函数ceil(),floor(),round()函数得应用
ceil()返回向上取整最接近的整数. double ceil(double); floor()返回向下取整最接近的整数. double floor(double); round()用于对浮点数的四舍 ...
- MyBatis学习(二)代码实战
一.项目依赖 本项目是基于mybatis3.4.6版本实现的,用到的jar包如下 二.项目结构解析 三.配置文件解析 四.mapper文件解析 <?xml version="1.0&q ...
- Java源码赏析(一)Object 类
写这个系列的原因,其实网上已经有无数源码分析的文章了,多一篇不多,少一篇不少,但为什么还要写这部分文章呢?于私,其一,上班族已经很久没有打过完整的一整段有意义的话,算是锻炼个人的书写.总结能力,其二, ...
- Cookies题解
来源:<算法竞赛进阶指南> Describe: 有M块饼干要分给N个孩子.当有k个孩子分到的饼干数比第i个孩子分到的多时,会产生g[i]*k的贡献.求最小的贡献及任意一种方案. Solut ...
- 绝了!这款工具让SpringBoot不再需要Controller、Service、DAO、Mapper!
Dataway介绍 Dataway 是基于 DataQL 服务聚合能力,为应用提供的一个接口配置工具,使得使用者无需开发任何代码就配置一个满足需求的接口.整个接口配置.测试.冒烟.发布,一站式都通过 ...