由于有时可以创建疯狂的SQL,因此分析LINQ查询及其执行计划尤为重要.
我经常发现我需要跟踪特定的查询,并且很难在查询分析器中查找.我经常在一个有很多正在运行的事务(有时候是生产服务器)的数据库上这样做 - 所以只是打开Profiler并不好.
我也发现tryin使用DataContext来追踪不足,因为它不会给我SQL我实际上可以自己执行.
到目前为止,我最好的策略是在查询中添加一个"随机"数字,并在跟踪中对其进行过滤.
LINQ:
where o.CompletedOrderID != "59872547981"
Run Code Online (Sandbox Code Playgroud)
Profiler过滤器:
'TextData' like '%59872547981'
Run Code Online (Sandbox Code Playgroud)
这有几点需要注意:
你无法在你的应用程序中运行查询,并在没有任何额外努力的情况下看到它在Profiler中弹出.只是希望其他人提出比这更好的方法,或者至少建议一个不那么"危险"的令牌来搜索而不是查询列.
我们希望将Linq to SQL用于项目.这是我们第一次使用Linq.通常我们只使用存储过程调用.
到目前为止,一切都运行良好,但DBA正在询问我们是否可以用在Profiler中可见的方式标记Linq生成的SQL查询.
我用Google搜索并搜索了Stackoverflow,我找到了各种方法来记录生成的SQL.但那不是我想要的.我认为如果我能将SQL注释粘贴到生成的SQL中,那将是理想的.这会在Profiler中可见吗?
谢谢你的任何想法!