- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个看起来像这样的查询:
SELECT ct,
text AS ST,
kval.idkwd
FROM (SELECT ST = kv.idkwd,
Count(kv.idkwd) CT,
kv.idkwd
FROM mwf
INNER JOIN info
ON mwf.ident = info.idinfo
INNER JOIN rel
ON rel.idinfo = info.idinfo
INNER JOIN pers
ON pers.idpers = rel.idpers
LEFT JOIN kwd kv
ON kv.idkwd = info.kwsvstatus
WHERE mwf.id IN ( :mwfIds)
GROUP BY idkwd) kw
INNER JOIN kwd kval
ON kw.idkwd = kval.idkwd
ORDER BY text
在 ASP.NET 应用程序中,此查询使用 NHibernate 以这种方式执行:
session.CreateQuery(query);
query.SetParameterList("mwfIds", mwfIds, NHibernateUtil.Guid);
return query.List();
出于未知原因,有时需要 30 秒才能运行(对于某些给定参数)。这些措施由 SQL Profiler 给出。
我尝试在 SSMS 上使用相同的参数执行相同的查询(从 SQL Profiler 输出复制),它运行不到 1 秒。
更糟糕的是,如果我将 C# 代码更改为
session.CreateQuery(hardcodedQuery);
return query.List();
其中 hardcodedQuery
与我在 SSMS 中运行的查询相同(即与往常一样,只是没有使用 NH 设置任何参数),它的运行时间也不到 1 秒。
为什么参数化查询要花这么多时间?
最佳答案
正如 Sean Lange 所说 in his comment这种行为很可能是由参数嗅探引起的。
根据我的经验,它总是通过修复索引来解决。 (不要太快添加索引,索引太多可能会导致其他性能问题。例如查询优化器选择错误的索引,导致临时数据库溢出。)
参数嗅探不仅仅发生在存储过程中。通过示例,它发生在通过 sp_executesql
或 EXEC()
执行的 sql 查询上。它甚至可能发生在查询中创建的自动参数化标量值中。
参数嗅探是 SQL Server 在缺少索引的情况下使用的优化回退。它使用特定参数值为第一个查询生成查询计划,然后将其缓存在查询计划缓存中。对具有不同参数值和相似连接属性的同一查询的所有后续调用都将使用该查询计划,无论参数值是什么。
如果第一个查询调用的值对应于从一个表中产生高过滤条件的极端情况,但其他调用值不会导致相同的高过滤,则缓存的查询计划会导致它们执行不佳。
SSMS 很少有与您的应用程序相同的连接选项,导致它不会重用应用程序使用的缓存查询计划。如果您缺少索引,则会生成另一个查询计划,以适应您正在测试的查询参数值。所以 SSMS 似乎表现更好......但不,它只是使用为您正在测试的特定参数值量身定制的查询计划。
可以在 Slow in the Application, Fast in SSMS? Understanding Performance Mysteries 中阅读更详细、准确和充分的解释。博文。
不要被它原始的一面吓倒,在我看来,这个博客是一个很好的资源。不要被 SQL Server 如何编译存储过程 标题所迷惑,他在标题后的第二句话中写道:
If your application does not use stored procedures, but submits SQL statements directly, most of what I say this chapter is still applicable.
这篇博文还将为您提供有关如何解决此类问题的指导。
关于c# - 为什么这个参数化的 SQL 需要很长时间,而同一个硬编码的 SQL 会立即执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36042121/
算力时代,视频云需要怎样的 CPU? 在数据爆发式增长及算法日益精进的大背景下,属于「算力」的时代俨然到来。随着视频成为互联网流量的主角,日趋饱和的音视频场景渗透率、人类对“感官之限”的追
我正在使用 keras 开发深度网络。有一个激活“硬 sigmoid”。它的数学定义是什么? 我知道什么是 Sigmoid。有人在Quora上问了类似的问题:https://www.quora.com
我有一个不寻常的 SQL 问题,我不太确定如何最好地解释,所以请耐心等待。我有三张表,一张是志愿者组织的表,一张是用户的表,一张是用户详细信息的表。 #Table 1# ## Name Preside
我正在尝试使用名为 bigText 的 jquery 插件。一个很棒的用于创建 block 头的插件。如果您想将其与自定义字体一起使用,它会声明您需要 google webfont loader,这样
假设我有一张 table date,personid 1/1/2001 1 1/2/2001 3 1/3/2001 2 1/4/2001 2 1/5/2001 5 1/6/2001 5 1/7/200
下面是我要执行的 SQL。我想避免为此执行多个请求,我很确定这是可能的…… First table : products_categories (category_id, category_infos
我在 android studio 中重新设置了一些提交,并选择了硬重置类型。我失去了一个星期的工作。是否有希望撤销此操作?我正在使用 android studio,它有内置的 GUI 选项来执行所有
当我使用我的交叉工具链编译 C 代码时,链接器会打印出警告页面,说明我的可执行文件使用了硬 float ,但我的 libc 使用了软 float 。有什么区别? 最佳答案 硬浮点使用片上浮点单元。软
linux系统有arm64,arm架构armv8-a。如何知道 debian 是运行硬浮点还是软浮点? 最佳答案 符合 AAPCS64, GNU GCC for armv8 仅提供硬浮点 aarch6
我正在开发 cortex-m3 的微内核。我创建了一个故意导致错误的小型测试应用程序。 现在我不确定如何从故障中返回。我知道堆栈可能需要使用不同函数的地址进行更新。我也知道在某些情况下从错误返回可能是
硬/软 限制是什么意思? 核心文件大小的差异例如: ulimit -Sc 1024 与 ulimit -Hc 1024 我通常在运行二进制文件之前将脚本放入 ulimit -c unlimited。
我想在 Java 中加载一个 MSCAPI keystore 并检查 MY 存储中的可用证书。但是,这些证书的一些 key 驻留在硬件 token 上,并且弹出窗口会在加载期间询问 token 。 有
是的,这是一个有点棘手的问题; 一个数组(没有副本),而不是任何奇数数组。让我解释一下,让我们从这里开始; $a = array ( 'one' => 1, 'two' => 2, 'three' =
我需要在运行 Ubuntu 12.04 的 BeagleBoard xM rev C 上运行一个使用 ftd2xx 的程序。我正在尝试使用提供的 ARM 库 libftd2xx.so here . l
我是一名优秀的程序员,十分优秀!