作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我选择带有查询的所有行时:
SELECT *
FROM AFT_Contacts
ORDER BY Tries
我看到了结果:
ID Name Area Phone Status Tries
------------------------------------------------------
117970 Adam One 1111111111 New 0
117971 Brian Two 2222222222 New 0
117972 Colin Three 3333333333 New 0
117973 David Four 4444444444 New 0
117974 Edward Five 5555555555 New 0
117975 Frank Six 6666666666 New 0
但是查询:
SELECT TOP 1 *
FROM AFT_Contacts
ORDER BY Tries
返回:
ID Name Area Phone Status Tries
-----------------------------------------------------
117971 Brian Two 2222222222 New 0
为什么它不返回 Adam 的详细信息,因为它们位于表中的第一位?
最佳答案
在关系数据库中,表没有固有的顺序。您给出的 ORDER BY
在所有记录中并不不同,事实上它在所有记录中都是相同的。因此返回结果的顺序仍然是不确定且不可预测的。因此 top 1
返回不可预测的行。
你说“Adam 的详细信息在表格中排在第一位”,这根本不是事实;表中的记录没有任何顺序存储。如果您选择没有 order by
或(如您的情况)order by
不确定,则返回的顺序是任意的。
关于sql - 为什么选择 TOP 1 . 。 。 ORDER BY 返回表中的第二行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40806487/
我是一名优秀的程序员,十分优秀!