- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个旧版 .Net 4 项目(将其命名为“A”),它使用 Linq-to-SQL 来查询数据库,并且我有 另一个 .Net 4 项目(将其命名为“B”),它具有类似但不同的代码,它查询与“A”相同的数据库。
两个项目:
自动生成的 DataContext特定于每个项目,但以相同的方式实例化:
Linq 查询的构建方式对于项目而言并不完全相同,但生成的 Linq 查询是相同的。生成的 (T-)SQL select 语句也是一样的! (监控并验证数据库服务器上的 SQL 句柄)
数据库服务器是:
如果运行受监控的 CPU项目“A”的查询时间(在数据库服务器上)急剧增加,并抛出命令超时异常。(System.Data.SqlClient.SqlException:超时已过期)
另一方面,“B”的查询在 (大约 3 秒) 内执行。通过使用相同参数再次调用“A”的代码,我能够重现该行为(不更改代码或数据库)。“B”甚至在几秒钟内执行,同时“A”正在增加其 CPU 时间。
遗憾的是,在同事重新创建索引后,我无法再重现该行为。同一位同事提到查询在“上个月”运行得很快(尽管与“上个月”相比没有代码更改...)。
我调试了两个项目的代码 - 两个 DataContext 实例看起来很相似。数据库服务器进程的 sql 句柄包含相同的 SQL 语句。但是“A”抛出超时异常,“B”在几秒钟内执行 - 重复!
为什么相同的 Linq-to-SQL 查询在项目“A”的数据库服务器上消耗的 CPU 时间比项目“B”多得多?
准确地说:如果查询由于某些原因运行“缓慢”——重复——同一个查询如何运行得更快,仅仅因为它被另一个 Linq-to-SQL 代码调用?
会不会有我(还)不知道的副作用?是否有一些 DataContext 的实例值我必须专门查看运行时?
顺便说一句:SQL 语句 - 通过 SSMS - 确实在每次运行时使用相同的查询计划。
为了完整起见,我链接了一个示例:
请记住,我不能透露完整的数据库模式、代码或我正在查询的实际数据。(SQL 表除了命名的列之外还有其他列,并且 C# 代码有点复杂,因为 Linq 查询是有条件地构造的。)
两个 DataContext
实例的一些属性:
Log = null;
Transaction = null;
CommandTimeout = 60;
Connection: System.Data.SqlClient.SqlConnection;
SqlConnection 是从这样的连接字符串创建的(两种情况):
"Data Source=server;Initial Catalog=sourceDb;Persist Security Info=True;User ID=user;Password=password"
没有运行明确的 SqlCommands 来将 SET
选项传递给数据库 session 。都不包含内联 TVF SET
选项。
最佳答案
您需要在 SQL Server 上设置 run a trace,而不是从 C# 端调试它。这将向您显示 A
和 B
在服务器上执行的所有内容。执行计划对你没有好处,因为它恰恰是 - 只是一个计划。您想要查看确切 语句及其实际 性能指标。
在极少数情况下,您会告诉我这两个 SELECT
语句完全相同但性能却大不相同,我几乎可以肯定它们在不同的 transaction isolation levels 下运行.单个 SQL 命令是一个隐式事务,即使您没有显式创建任何命令也是如此。
如果出于某种原因跟踪没有明确说明,您应该发布正在运行的命令及其指标。
注意:运行跟踪会产生一些性能开销成本,因此我会尽量保持较小的时间范围或尽可能在非高峰期运行。
关于c# - 为什么相同的 Linq-to-SQL 查询会在不同项目的数据库服务器上消耗更多的 CPU 时间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25687391/
我正在开发一个带选项卡栏的 ios 应用程序。我的栏上有超过 5 个按钮,所以在 iphone 上我有更多的按钮。现在,假设我有这个按钮:Button1 Button2 Button3 Button4
我有一个带有 UITabBarController 的应用,其中有超过五个选项卡。 当我按更多选项卡时,我会转到moreNavigationController,它是一个UINavigationCon
我有一个导航 Controller 。 NAVC->MORE... 按钮,然后在“更多”下有一些额外的 VC。 如果我转到“更多...”下的 VC,然后转到不在“更多...”上的 VC,那么当我返回到
因此,我想出了这种方案,用于在多个线程同时具有读写访问权限的二叉树中旋转时锁定节点,这涉及每次旋转锁定四个节点,这似乎是一个很多吗?我想到了一种比我想出的方法更聪明的方法来减少所需的锁定,但谷歌并没有
所以我已经尝试了所有方法,但我似乎仍然无法将下拉内容与 dropbtn 对齐。我只希望内容始终位于更多菜单下方。 HTML: `
我正在尝试使用 expect 来自动接受在 --more-- 中提示的 EULA。 #!/usr/bin/expect spawn "./greenplum-perfmon-web-4.1.2.0-b
他们如何在下面提供的网站上制作“告诉我更多”效果。我读过 read more/less effect in jQuery,但我发现该站点的有趣之处在于,除非单击该按钮,否则无法滚动页面。 Effect
现在,Kim Stebel helped me understanding如何使用存在类型键入变量,我需要知道如何在继承中使用它们: 以下代码无法编译: class PagingListModel(s
在我的Cygwin中不可用。另一方面,提供了“ less”命令。也许Cygwin的制造商认为“更多”只是多余的。 我对此很好奇。 最佳答案 安装util-linux软件包,您将获得“更多”的信息 ht
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我们使用 asp.net mvc、javascript 和 jQuery(托管在本地计算机上)创建了一个应用程序。基本设计是,当用户从一个页面导航到其他页面时,我们通过隐藏和显示 HTML 页面,将所
我想用 RMonad 做一些基本的事情。有没有办法使用“as monad”功能来 有一个身份 rmonad,可以应用 monad 转换器吗? 有诸如 StateT 变压器之类的常见东西吗? 向现有 m
我有一个 char*[] 数组。我需要能够为其分配字符串并再次删除它们,但我不知道: 如何检查一个元素中是否已经有一个字符串,这样我就不会覆盖它,如果它已经被占用,则继续处理下一个元素? 之后如何将其
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我有一个程序可以同时吐出标准错误和标准输出,我想在标准错误上少运行寻呼机,但忽略标准输出。我该怎么做? 更新: 就是这样......我不想丢失标准输出......只是让它远离寻呼机 program 2
基本上,当单击具有类 "dropdown" 的链接时,我无法获取“更多...”链接来对下一个跨度的高度进行动画处理。它根本就没有动画。仅当更改为 Less... 链接并且单击 Less... 链接以折
我正在使用 ExtJS,并认为它是一个了不起的框架。但是,它们没有内置的状态图,这使得依赖于状态的应用程序开发非常痛苦。 我最近发现了这个: https://github.com/jakesgordo
我一直在研究数据结构和算法,遗憾的是在C中。我已经单独实现了一个双向链表,它保存整数并且工作正常,但是当节点(或pub)让它正常工作时我遇到了很多麻烦在本例中)保存多个不同类型的值。我可以创建一个列表
编辑拼写错误 你好, 这可能是一个愚蠢的问题,但如果它能帮助我遵循最佳实践,我不在乎:P 假设我想在 System.Data 命名空间...以及 System.Data.SqlClient 命名空间中
使用 bootstrap 3 CSS、font awesome CSS 和最新的 jQuery JS 文件。 我正在使用 javascript 在单击按钮时在另一个内容 div 之上隐藏/显示一个内容
我是一名优秀的程序员,十分优秀!