我在给定查询中遇到了记录顺序的问题。
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。
发布于 2012-07-18 12:15:06
除非由ORDER BY子句指定,否则数据库查询返回的行的顺序是未定义的。由于只按ET.st排序,并且此列的所有值都相同,因此结果将以不确定的顺序返回(基于优化器确定的计划和使用的索引顺序)。更新索引统计信息允许查询优化器选择最佳(通常是最具确定性的)索引;查询计划可能因此而发生更改,从而导致出现不同的排序。
在我看来,您想要按ET.st以外的其他东西进行排序。
https://stackoverflow.com/questions/11534181
复制相似问题