- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在寻找为什么会这样或我可以加快速度的方法。
我基本上用这样的代码构造了一个对象
(伪代码)
Person p = new Person();
Address a = new Address() { ... properties set here ... };
Employer e = new Employer() { ... properties set here ... };
// etc.
p.Employer = e;
p.Address = a;
//etc.
最后:
_context.Person.Add(p);
当我分析代码时,这个人的构建需要 0 毫秒,快如闪电。但是,当我将此人添加到上下文中时,大约需要 1500 毫秒。可能与约束检查有关吗?数据库非常大,虽然它没有加载到内存或任何东西中,所以在它执行 Add
时它不应该触及数据库。
只有当我执行 _context.SaveChanges()
时才应该写入。
有什么提高速度的建议吗?
编辑:基准测试是这样完成的:(sw 是一个 new Stopwatch()
)
sw.Restart();
context.Person.Add(p);
Console.WriteLine("Person added to context: " + sw.ElapsedMilliseconds + "ms");
编辑 2:情节变厚。
当我加载大量人员并将他们添加到数据库中时,我要做的第一个操作是查看该人员是否已存在于数据库中。出于速度原因,我将 Person.PersonId 的完整列表拉入哈希表并检查它们以查找要插入的每条记录。
如果这个人已经存在于列表中,我会把他们从数据库中拉出来。这需要大约 5 毫秒,我没有对数据做任何事情(因为我还没有写那部分),只是跳到下一个。
然而,当它到达正在添加到上下文中的新条目时,正是那条线导致了巨大的减速。这是代码:
matchPerson = _context.Person.SingleOrDefault(c => c.PersonId == intPersonId);
因此,如果他们已经在数据库中,它会通过 0ms 哈希表检查(即时)将此人从数据库中拉出。
执行此操作大约需要 5 毫秒。
如果我在出现此行时执行上述 _context.Add
,它会变得非常慢。如果我将其注释掉,则大约需要 40 毫秒,并且每添加一条记录都会增加(因此在 2,000 条记录之后大约需要 200 毫秒)。
我看不到这两行之间的链接,所以也许上下文查询重置了上下文的状态并减慢了下一个操作?
最佳答案
根据评论中的要求(如果这不是关闭重复项),减速与自动更改检测有关,它在 DbContext
API 中默认启用。
要禁用自动更改检测:
context.Configuration.AutoDetectChangesEnabled = false;
可以在这个已接受的答案中找到更完整/完整的描述(我在这里当然不能更好):
Why is inserting entities in EF 4.1 so slow compared to ObjectContext?
关于c# - 将对象添加到 Entity Framework 上下文大约需要 1.5 秒,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18507201/
我需要围绕半径大约为 X 米的点 (lon,lat) 创建一个圆。 该点是通过等效于 geomFromEwkt('SRID=1;POINT(lon lat)') 生成的。 我知道 postgis 的缓
代码实现了读取文件(包含大量url)的功能,每个url都通过“evhttp_uri_parse”获取主机和路径。但是有一个错误,evhttp_uri_parse解析失败,返回NULL。可能原因是堆栈溢
所以我有两个进程,一个客户端进程,一个服务器进程。用户可以向客户端发出命令,当用户输入命令时客户端会将命令长度发送给服务器,之后再发送实际的命令。 服务器首先发回响应的长度,然后发送回响应。 我可以执
我从enwiki-latest-pagelinks.sql.gz下载了dumps.wikimedia.org/enwiki/latest/转储。 我开始将表导入到mysql数据库中: mysql -D
我有一个带有 Jw 音频播放器的 php 页面,并且有大约 5500 个链接,在每个链接的 onclick 事件上都附加了一个 javascript 函数。 php 正在生成文件的确切相对路径和名称,
我有一个大约 2GB 的巨大文本文件,我试图用 C# 解析它。该文件具有行和列的自定义分隔符。我想解析文件并提取数据并通过插入列标题并将 RowDelimiter 替换为换行符并将 ColumnDel
我已经建立了几个网站,出于某种原因,当我“喜欢”一篇博客文章或喜欢这个网站时,它们都不会再贴到我的墙上了。 (使用 iframe)示例: http://madhatterulti.com/ http:
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
我有一个与 LongPoll 一起工作的服务,当我收到我的数据时一切正常,但是当我没有收到数据时,我收到的是空结果(长轮询最大时间 == 25 秒)我的服务有时会关闭手动(我没有在服务列表中看到它)。
对于用于 Android 和应用内购买的最佳支付 API 是否达成共识? 在谷歌上搜索“Android 支付 api”,有大量来自 paypal、sms 和信用卡公司等的点击。但其中大部分文章已有多年
我的查询执行时间很长,大约 120 秒。 任何人都可以帮我重写这个查询。 请参阅下面的解释计划和表格结构。 我们经常在慢日志中收到此查询。 查询: select count(*) as col_
我正在尝试找到一种方法来对墓 map 像进行近似分割(在文化科学中的 CBIR 背景下 - 但这不是主题)。到目前为止,我正在使用这个策略: 模糊图像两次(实验结果) 应用 Canny 边缘检测器 寻
当您在 Google 中搜索时(我几乎可以肯定 Altavista 做了同样的事情),它会显示“关于 xxxx 的结果 1-10”... 这一直让我感到惊讶......“关于”是什么意思? 他们怎么能
今天我们的一台 Linux 服务器在打开出站请求时遇到问题。我已经查看了这个答案,Increasing the maximum number of tcp/ip connections in linu
我在 MVC4 站点中使用 NuGet 的最新 SignalR。使用sample hub code (或任何代码),我遇到一些奇怪的连接问题。一切加载正常,SignalR 进行协商调用并记录“Even
有人可以帮帮我吗?我的 GUI 有问题。这会过快地接收过多数据,以至于事件处理程序会完全阻塞 GUI 以供用户输入。 后台程序用于向 GUI 发送解决方案(作为文本),但 GUI 处理数据的速度不够快
假设我有一段代码,例如 for (j = 0; j 180) { c.fillStyle = 'red' } c.fi
我正在创建 2 名玩家的游戏,每个玩家都有自己的区域。我希望每个玩家都可以用一根手指触摸自己的区域。所以首先我将“达阵”功能限制为“2 个指针”。 public boolean touchDown(i
进程运行卡在 32000 (± 5%) 左右 ~# cat/proc/sys/kernel/threads-max127862 ~# ulimit -s堆栈大小(千字节,-s)2048 可用内存:3,
我有一个问题。我的应用程序在某些 Android 设备(Android 版本 5 到 6)的后台运行(如前台服务)。应用程序连接到服务器(TCP 连接)并且它们至少每 45 秒交换一次数据。 如果屏幕
我是一名优秀的程序员,十分优秀!