当前位置:  开发笔记 > 数据库 > 正文

在SQL事件探查器中查找特定LINQ查询的巧妙技巧

如何解决《在SQL事件探查器中查找特定LINQ查询的巧妙技巧》经验,为你挑选了1个好方法。

由于有时可以创建疯狂的SQL,因此分析LINQ查询及其执行计划尤为重要.

我经常发现我需要跟踪特定的查询,并且很难在查询分析器中查找.我经常在一个有很多正在运行的事务(有时候是生产服务器)的数据库上这样做 - 所以只是打开Profiler并不好.

我也发现tryin使用DataContext来追踪不足,因为它不会给我SQL我实际上可以自己执行.

到目前为止,我最好的策略是在查询中添加一个"随机"数字,并在跟踪中对其进行过滤.

LINQ:

where o.CompletedOrderID != "59872547981"

Profiler过滤器:

'TextData' like '%59872547981'

这有几点需要注意:

我必须小心记住删除标准,或选择一些不会影响查询计划的东西.是的,我知道离开它是在惹麻烦.

据我所知,即使采用这种方法,我也需要为我需要跟踪的每个LINQ查询启动一个新的跟踪.如果我为现有跟踪转到'文件>属性',我无法更改过滤条件.

你无法在你的应用程序中运行查询,并在没有任何额外努力的情况下看到它在Profiler中弹出.只是希望其他人提出比这更好的方法,或者至少建议一个不那么"危险"的令牌来搜索而不是查询列.



1> KristoferA..:

搞乱where子句可能不是最好的事情,因为它可以并且会影响查询的执行计划.

通过投射到匿名类来做一些时髦的事情 - 使用唯一的静态列名或不会影响执行计划的东西.(这样你就可以在生产代码中保留它,以防你以后需要对生产代码进行任何分析......)

from someobject in dc.SomeTable
where someobject.xyz = 123
select new { MyObject = someobject, QueryTraceID1234132412='boo' }

推荐阅读
吻过彩虹的脸_378
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有