繁体   English   中英

mssql查询顺序每次都在变化

[英]Mssql query sequence is changing every time

对于 Erp 版本升级,我们复制了我们的数据库并恢复到新的。 我们改变了桌子。 (添加新列或更改宽度等。我们删除索引并重新创建)。 毕竟我们测试了新数据库,遇到了这样的情况。

我们有一个类似的查询

select top 5 * from table. 

旧数据库:当我们连续运行查询时,结果顺序不变

新数据库:当我们运行时,结果的顺序发生变化。

我认为存在聚集索引问题,但我不知道如何确定和解决它。 有什么帮助吗?

除非您使用 order by,否则无法保证订单。

旧数据库可能在表上创建了聚集索引。 请检查一下。 但即使是聚集索引也不能总是保证排序。

如果在 TOP 语句之后不使用 ORDER BY 语句,则数据库引擎不保证结果集的顺序。 SQL 服务器希望在某些情况下快速返回合格的行,这种机制称为行目标,很可能您的查询执行计划使用这种机制。 另一方面,聚集索引运算符包含一个有序属性,这向我们展示了检索到的行是否以有序方式获取。 在此处输入图像描述

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM