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.
这篇关于“选择"是否总是按主键排序?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:“选择"是否总是按主键排序?


基础教程推荐
- SQL Server 2016更改对象所有者 2022-01-01
- Sql Server 字符串到日期的转换 2021-01-01
- SQL Server:只有 GROUP BY 中的最后一个条目 2021-01-01
- 如何在 SQL Server 的嵌套过程中处理事务? 2021-01-01
- 将数据从 MS SQL 迁移到 PostgreSQL? 2022-01-01
- SQL Server 中单行 MERGE/upsert 的语法 2021-01-01
- 使用pyodbc“不安全"的Python多处理和数据库访问? 2022-01-01
- 无法在 ubuntu 中启动 mysql 服务器 2021-01-01
- ERROR 2006 (HY000): MySQL 服务器已经消失 2021-01-01
- 在 VB.NET 中更新 SQL Server DateTime 列 2021-01-01