gpt4 book ai didi

sql - sp_executesql 导致我的查询非常慢

转载 作者:行者123 更新时间:2023-12-02 10:12:43 26 4
gpt4 key购买 nike

在数据库表上运行 sp_executesql 时遇到一些问题。在本例中,我使用 ORM (NHibernate) 生成一个查询一个表的 SQL 查询。该表大约有 700 万条记录,并且索引很高。

当我运行 ORM 在没有 sp_executesql 的情况下发出的查询时,它运行得非常快,并且探查器显示它有 85 次读取。当我使用 sp_executesql 运行相同的查询时,它有大约 201,828 次读取。

我需要在 SQL Server 上做些什么来提高在没有 sp_exectuesql 的情况下运行查询的性能吗?看起来好像它没有使用我的索引。

解决此问题的最佳方法是什么?如果可能的话,我宁愿不改变 ORM 生成 SQL 的方式,而是在 SQL Server/数据库级别修复问题,因为这似乎就是问题所在。我猜我需要对数据库进行更多优化来解决这个问题,我只是不知道是什么。

exec sp_executesql N'SELECT top 20 
this_.Id as Id0_0_,
this_.Application as Applicat2_0_0_,
this_.[Context] as column3_0_0_,
this_.Logger as Logger0_0_,
this_.Message as Message0_0_,
this_.Exception as Exception0_0_,
this_.Thread as Thread0_0_,
this_.[Level] as column8_0_0_,
this_.LogDate as LogDate0_0_,
this_.SessionId as SessionId0_0_
FROM LogMessages this_
WHERE this_.[Context] = @p0',
N'@p0 nvarchar(2)',
@p0 = N'55'

上下文是 varchar(255)。该字段的形式非常自由。它并不总是整数,而且长度可能很大。在本例中,我查询的是“55”值,但也可以轻松查询“Foooooobaaaarrr”

最佳答案

.[Context]使用相同的数据类型的数据类型是什么

现在您正在使用 nvarchar(2),但这对于 55 这样的东西来说似乎很奇怪,如果您不使用相同的数据类型,您将获得转换,然后导致扫描

根据您更新的问题,它看起来像是 varchar(255),然后执行此操作

WHERE this_.[Context] = @p0',N'@p0 varchar(255)',@p0='55'

关于sql - sp_executesql 导致我的查询非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3688015/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com