Does 'Select' always order by primary key?

前端 未结 6 965
无人共我
无人共我 2020-12-01 18:14

A basic simple question for all of you DBA.

When I do a select, is it always guaranteed that my result will be ordered by the primary key, or should I specify it wit

相关标签:
6条回答
  • 2020-12-01 18:53

    It depends on your DB and also it depends on indexed fields.

    For example, in my table Users every user has unique varchar(20) field - login, and primary key - id.

    And "Select * from users" returns rowset ordered by login.

    0 讨论(0)
  • 2020-12-01 18:57

    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.

    0 讨论(0)
  • 2020-12-01 18:59

    If you want your results in a specific order, always specify an order by

    0 讨论(0)
  • 2020-12-01 19:03

    No, ordering is never guaranteed unless you use an ORDER BY.

    The order that rows are fetched is dependent on the access method (e.g. full table scan, index scan), the physical attributes of the table, the logical location of each row within the table, and other factors. These can all change even if you don't change your query, so in order to guarantee a consistent ordering in your result set, ORDER BY is necessary.

    0 讨论(0)
  • 2020-12-01 19:05

    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'?

    No, it's by far not guaranteed.

    SELECT  *
    FROM    table
    

    most probably will use TABLE SCAN which does not use primary key at all.

    You can use a hint:

    SELECT  /*+ INDEX(pk_index_name) */
            *
    FROM    table
    

    , but even in this case the ordering is not guaranteed: if you use Enterprise Edition, the query may be parallelized.

    This is a problem, since ORDER BY cannot be used in a SELECT clause subquery and you cannot write something like this:

    SELECT  (
            SELECT  column
            FROM    table
            WHERE   rownum = 1
            ORDER BY
                    other_column
            )
    FROM    other_table
    
    0 讨论(0)
  • 2020-12-01 19:09

    If you desire specific ordering then declare it specifically using ORDER BY.

    What if the table doesn't have primary key?

    0 讨论(0)
提交回复
热议问题