首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >T-sql中的记录顺序随统计信息更新而更改

T-sql中的记录顺序随统计信息更新而更改
EN

Stack Overflow用户
提问于 2012-07-18 12:10:55
回答 1查看 98关注 0票数 0

我在给定查询中遇到了记录顺序的问题。

代码语言:javascript
复制
SELECT 
EA.eaid, --int , PK of table1
EA.an, --varchar(max)
EA.dn, --varchar(max)
ET.etid, --int
ET.st --int
FROM dbo.table1 EA
JOIN dbo.table2 ET ON EA.etid = ET.etid
JOIN @tableAttribute TA ON EA.eaid = TA.id -- TA.id is int and is not a PK
ORDER BY ET.st

对于给定场景中的所有记录,ET.st列的值都相同。

在更新统计信息时,查询给出的记录顺序是随机变化的。有时是EA.eaid的顺序,有时是TA.id的顺序。

请为这样的behaviour.How提供一个解释,这里的统计数据是否会影响排序?

我使用的是sql server2008 R2。

EN

回答 1

Stack Overflow用户

发布于 2012-07-18 12:15:06

除非由ORDER BY子句指定,否则数据库查询返回的行的顺序是未定义的。由于只按ET.st排序,并且此列的所有值都相同,因此结果将以不确定的顺序返回(基于优化器确定的计划和使用的索引顺序)。更新索引统计信息允许查询优化器选择最佳(通常是最具确定性的)索引;查询计划可能因此而发生更改,从而导致出现不同的排序。

在我看来,您想要按ET.st以外的其他东西进行排序。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11534181

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档