Does #39;Select#39; always order by primary key?(“选择是否总是按主键排序?)
问题描述
针对所有 DBA 的一个基本简单问题.
A basic simple question for all of you DBA.
当我进行选择时,是否总是保证我的结果将按主键排序,还是应该使用order by"来指定它?
When I do a select, is it always guaranteed that my result will be ordered by the primary key, or should I specify it with an 'order by'?
我使用 Oracle 作为我的数据库.
I'm using Oracle as my DB.
推荐答案
不,如果您不使用order by",则无法保证任何顺序.事实上,您不能保证从一个查询到下一个查询的顺序是相同的.请记住,SQL 以基于集合的方式处理数据.现在,一个或另一个数据库实现可能碰巧以某种方式提供排序,但您永远不应该依赖它.
No, if you do not use "order by" you are not guaranteed any ordering whatsoever. In fact, you are not guaranteed that the ordering from one query to the next will be the same. Remember that SQL is dealing with data in a set based fashion. Now, one database implementation or another may happen to provide orderings in a certain way but you should never rely on that.
这篇关于“选择"是否总是按主键排序?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:“选择"是否总是按主键排序?
基础教程推荐
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- 带更新的 sqlite CTE 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
