加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 数据库 > MsSql > 正文

sql – 数据库服务器如何决定哪个顺序返回行,而没有任何“order by”语句?

发布时间:2020-05-23 15:36:34 所属栏目:MsSql 来源:互联网
导读:一种异想天开的问题,总是有一些我想知道的事情,我知道为什么这样做会使我的理解有所加深. 假设我做“SELECT TOP 10 * FROM TableName”.在短时间内,相同的10行回来,所以看起来不是随机的.他们不是第一次或最后创建.在我的大量样本大小的一个表中,它没有返回最

一种异想天开的问题,总是有一些我想知道的事情,我知道为什么这样做会使我的理解有所加深.

假设我做“SELECT TOP 10 * FROM TableName”.在短时间内,相同的10行回来,所以看起来不是随机的.他们不是第一次或最后创建.在我的大量样本大小的一个表中,它没有返回最小或最大自动递增主键值.

我也认为考虑到连接问题变得更加复杂.

我的数据库选择是MSSQL,但我认为这可能是一个有趣的问题,无论平台如何.

解决方法

如果您不在SELECT语句中提供ORDER BY子句,您将以任意顺序返回行.

实际的顺序是未定义的,并且取决于哪些块/记录已经缓存在内存中,当数据库服务器中的线程计划运行时,执行什么顺序I / O,等等.

订单没有韵律或理由,除非您提供订单,否则您绝对不应该对订单行进行任何预期.

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读