数据库查询排序使用随机排序结果示例(OracleMySQLMS SQL Server)

数据库查询排序使用随机排序结果示例(OracleMySQLMS SQL Server),第1张

Oracle查询结果集,随机排序

复制代码

代码如下:

select

*

from

table1

order

by

dbms_random.value()

MySQL随机查询出一条记录:

复制代码

代码如下:

--

下面的查询语句效率高,不要使用

SELECT

*

FROM

table1

ORDER

BY

rand()

LIMIT

1

来查询

SELECT

*

FROM

table1

WHERE

id=(SELECT

id

FROM

table1

ORDER

BY

rand()

LIMIT

1)

查询结果集,随机排序

复制代码

代码如下:

SELECT

*

FROM

table1

ORDER

BY

rand()

MS

SQL

Server

复制代码

代码如下:

SELECT

*

FROM

Northwind

Orders

ORDER

BY

NEWID()

SELECT

TOP

10

*

FROM

Northwind

Orders

ORDER

BY

NEWID()

数据分页时需要根据数据记录创建时间create_time字段倒序,即使用order by create_time desc,但是我们会发现,前端进行请求时获取的数据并不正确,分页中出现了一定的重复数据。

由于大量数据是并发创建的,所以create_time字段值是相同的。这里会有一个很有趣的问题,当order by的字段相同的时候 系统对数据的排序可能变得随机,即一会儿这条数据在前面,一会儿这条数据在后面了 ,所以当翻页的时候我们很容易便看到了重复的数据。

查阅了Goole和相关资料,大概总结了这种情况的原因。其实发生这种现象是“故意”设计的。

  如果没有指定ORDER BY语句,则SQL Server(或任何RDBMS)不保证以特定顺序返回结果。 有些人认为,如果没有指定order by子句,行总是以聚簇索引顺序或物理磁盘顺序返回。 然而,这是不正确的,因为在查询处理期间可以改变行顺序的许多因素,例如并行的HASH连接是更改行顺序的 *** 作符的一个很好的例子。

  如果指定ORDER BY语句,SQL Server将对行进行排序,并按请求的顺序返回。 但是,如果该顺序不是确定性的,即可能有重复的值,则在每个具有相同值的组中,由于与上述相同的原因,该顺序是“随机的”。

  确保确定性顺序的唯一方法是在ORDER BY子句中包含保证的唯一列或列组(例如主键)。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9666802.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存