- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下查询(由 Entity Framework 使用标准分页生成。这是内部查询,我添加了 TOP 438 部分):
SELECT TOP 438 [Extent1].[Id] AS [Id],
[Extent1].[MemberType] AS [MemberType],
[Extent1].[FullName] AS [FullName],
[Extent1].[Image] AS [Image],
row_number() OVER (ORDER BY [Extent1].[FullName] ASC) AS [row_number]
FROM [dbo].[ShowMembers] AS [Extent1]
WHERE 3 = CAST( [Extent1].[MemberType] AS int)
ShowMembers 表大约有 11K 行,但只有 438 行,且 MemberType == 3。“Image”列的类型为 nvarchar(2000),用于保存 CDN 上图像的 URL。如果我在查询中包含此列(仅在 SELECT 部分),查询会以某种方式阻塞并生成 2-30 秒范围内的结果(在不同的运行中有所不同)。如果我注释掉该列,查询将按预期运行得很快。如果我包含“图像”列,但注释掉 row_number 列,查询也会按预期快速运行。
显然,我对 URL 的大小过于自由,所以我开始调整大小。我发现如果我将 Image 列设置为 nvarchar(884),那么查询将按预期运行得很快。如果我将其设置为 885,它又会变慢。这并不绑定(bind)到某一列,而是绑定(bind)到 SELECT 语句中所有列的大小。如果我只是将大小增加一,性能差异就很明显。
我不是数据库专家,所以欢迎任何建议。
PS 在本地 SQL Server 2012 Express 中不存在性能问题。
PPS 使用 OFFSET 0 ROWS FETCH NEXT 438 ROWS ONLY 运行查询(当然没有 row_count 列)也很慢。
最佳答案
Row_number 必须对所有行进行排序,才能按照您想要的顺序获得内容。在结果集中添加较大的列意味着所有列都已排序,因此速度会慢得多/执行更多 IO。顺便说一句,如果在调试此类问题时在 SSMS 中启用“setstatisticsioon”和“setstatisticstimeon”,则可以看到这一点。它将使您深入了解查询中运行时发生的 IO 数量和其他操作: https://learn.microsoft.com/en-us/sql/t-sql/statements/set-statistics-io-transact-sql?view=sql-server-2017
就如何使此查询运行得更快而言,我鼓励您考虑一些可能会稍微改变数据库架构设计的事情。首先,考虑您是否确实需要按特定顺序对行进行排序。如果您不需要按顺序排列内容,那么在没有 row_number 的情况下迭代它们会更便宜(通过可测量的量)。因此,如果您只想在概念上对每个条目进行一次迭代,则可以通过按仍然单调的更静态的内容(例如标识列)进行排序来实现此目的。其次,如果您确实需要对事物进行排序,那么请考虑它们是否经常/不经常更改。如果不常见,则可以只计算一个列值并将其保留到具有所需相对顺序的每一行中(并在每次修改表时更新它)。在此模型中,您可以为新列建立索引,然后按该顺序请求内容(按查询中的顶级顺序 - 不需要 row_number)。如果您确实需要像您正在做的那样进行动态计算,并且始终需要按照精确的顺序进行计算,那么您的最终选择是将 URL 移至第二个表并在 row_number 之后与其连接。这将避免在计算 row_number 时出现“宽”排序。
祝你好运
关于performance - SQL Azure - 如果包含具有大尺寸 nvarchar 的列,则使用 row_number() 的查询执行速度会很慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27943913/
将 nvarchar(max) 转换为 nvarchar(n) 并指示有更多数据的最快方法是什么? 例如:将列地址转换为 nvarchar(100),如果地址大于 100 个字符,则将最后 3 个字符
SO 和其他网站上都有多个帖子明确指出 nvarchar(max) 的最大长度是 2GB。但是,我在互联网和现实生活中也看到很多困惑,它实际上是 Unicode 中的 8000/4000。 我想知道什
我刚刚将表中的一个 nvarchar(MAX) 字段更改为 nvarchar(250)。有人可以告诉我如果条目超过 250 个字符,数据会发生什么情况吗? 我关心的不是可见数据,而是幕后发生的事情:
如果下面两个表的唯一区别是 nvarchar(50) 与 nvarchar(max) 以及每个表中的字符串,它们之间的一般存储和性能差异是什么字段范围从 1 到 50 个字符?这是在 SQL Serv
我在 SQL SERVER 2008 中有一个现有表,其中一列为 NVARCHAR(MAX) 并且其中只有少于 10 个字符的值。 此表正在生产中,其中包含数据。 我有一个要求,我必须将此列从 NVA
我正在构建一个表来跟踪数据库中特定对象的历史记录。目前我有以下列: HistoryId int IDENTITY(1,1) NOT NULL HistoryDate datetimeoffset(7)
在最终向用户呈现结果集之前,我对表变量进行了大量工作。例如,我可能会从许多不同的表中提取全部列,如下所示: DECLARE @tmp TABLE ( ID int, username nvarchar
我今天在 SQL Server(2008R2 和 2012)中遇到了一个非常奇怪的问题。我正在尝试结合使用连接和 select 语句来构建一个字符串。 我已经找到了解决方法,但我真的很想了解这里发生了
例如,nvarchar(max) 的性能是否低于 nvarchar(100)? 最佳答案 here (SO) 和 here (MSDN) 回答了同样的问题 引用 David Kreps 的回答: Wh
我们的 SQL Server(2005 和 2008)数据库中有几个表,其中的列定义为 nvarchar(4000)。我们有时需要能够存储比这更多的数据,并考虑改用 nvarchar(max)。现在回
当你在 fluent NHibernate 中设置一个字符串值时,它总是将 DB 值设置为 Nvarchar(255),我需要存储相当多的基于用户输入的长字符串,而 255 是不切实际的。 补充一下,
我在 sql 中有一个列,在某些情况下有时是 nvarchar 和数字。该列的数据类型为 nvarchar 。我只对我不需要它的数字的地方感兴趣。我使用如下案例 (SELECT case when i
在 SQL Server 中,如果您创建一个 NVARCHAR(MAX) 类型的列,并且仅在其中填充 128 个字符 - 与将其创建为 NVARCHAR 相比,它是否会消耗更多的存储空间(128) -
我们有一个索引列(ModelName),它在表中非常重要,并且与“目录号”非常相似,但它不是 PK。 大量按 ModelName 订购 ;正在使用 WHERE ModelName 等。 该列最初为 N
使用 SQL Server 2014,我有一个表,其中有 nvarchar(max)名为 [ASCII File] 的列它可以包含许多 K 的 ASCII 文本文件。然后我想对该文件执行 MD5 哈希
如何将 NTEXT 列转换为 NVARCHAR(MAX)? 我有 4 个数据库,其中有一个表存在于所有四个数据库中。在此表中,存在一个类型为 NTEXT except 的 Notes 列,该列为 nv
我面临的情况是必须使用脚本将现有数据库结构从 varchar 更新为 nvarchar。由于每次运行配置应用程序时都会运行此脚本,因此我宁愿确定列是否已更改为 nvarchar,而不是对表执行更改。我
我想知道定义 nvarchar(max) 类型的列而不是为其指定(较小的)最大大小是否有任何缺点。 我在某处读到,如果列值超过 4?KB,则剩余数据将添加到“溢出”区域,这是可以的。 我正在创建一个表
我想更改表 stk020 中的列类型。所以,我使用了这个查询.. ALTER TABLE [stk020] ALTER COLUMN [t16] nvarchar(Max) not null [t16
我正在尝试将存储在 CONTEXT_INFO 中的 nvarchar 转换回。 declare @LanguageCode nvarchar(6) = 'en'; declare @binvar va
我是一名优秀的程序员,十分优秀!