概述
当我决定在我的新项目中使用OR / M(
MySQL的实体框架)时,我希望它能节省我的时间,但我似乎已经失败了(现在第二次).
采用这个简单的SQL查询
SELECT * FROM POST ORDER BY addedOn DESC LIMIT 0, 50
它执行并在不到一秒的时间内给出结果(表格大约有60,000行).
这是我为此编写的等效LINQ To Entities查询
var q = (from p in db.post
orderby p.addedOn descending
select p).Take(50);
var q1 = q.ToList(); //This is where the query is fetched and timed out
但是这个查询从来没有执行它总是超时(没有命令,需要5秒才能运行)!我的超时时间设置为12秒,因此您可以想象它的速度远不止于此.
>为什么会这样?
>有没有办法可以看到实体框架向数据库发送的实际SQL查询是什么?
>我是否应该放弃使用EF MySQL并转向标准SQL,然后才能让它失去所有永恒的功能?
我重新校准了我的索引,尝试了急切的加载(即使没有orderby子句,它实际上也会失败)
请帮助,我即将放弃OR / M for MySQL作为一个失败的原因.
最后
以上就是敏感丝袜为你收集整理的实体是什么MySQL_实体框架MySQL – 为什么性能如此糟糕?的全部内容,希望文章能够帮你解决实体是什么MySQL_实体框架MySQL – 为什么性能如此糟糕?所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复