亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關于PostgreSQL 行排序的實例解析

 更新時間:2021年01月12日 10:17:45   作者:Ryan_zheng  
這篇文章主要介紹了關于PostgreSQL 行排序的實例解析,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

在查詢生成輸出表之后,也就是在處理完選擇列表之后,你還可以對輸出表進行排序。

如果沒有排序,那么行將以不可預測的順序返回(實際順序?qū)⑷Q于掃描和連接規(guī)劃類型和在磁盤上的順序,

但是肯定不能依賴這些東西)。確定的順序只能在明確地使用了排序步驟之后才能保證。

ORDER BY子句用于聲明排序順序:

SELECT _select_list_
  FROM _table_expression_
  ORDER BY _sort_expression1_ [ASC | DESC] [NULLS { FIRST | LAST }]
       [, `_sort_expression2_` [ASC | DESC] [NULLS { FIRST | LAST }] ...]

sort_expression 是任何可用于選擇列表的表達式,可以將不同列相加減乘除后排序,例如:

SELECT a, b FROM table1 ORDER BY a + b, c;

如果指定了多個排序表達式,那么僅在前面的表達式排序相等的情況下才使用后面的表達式做進一步排序。

每個表達式都可以跟一個可選的ASC(升序,默認) 或DESC(降序)以設置排序方向。 升序先輸出小的數(shù)值,這里的"小"是以<操作符的角度定義的。

類似的是,降序是以>操作符來判斷的。

NULLS FIRST和NULLS LAST選項可以決定在排序操作中在 non-null 值之前還是之后。

默認情況下,空值大于任何非空值;也就是說,DESC 排序默認是NULLS FIRST,否則為NULLS LAST。

注意,排序選項對于每個排序列是相對獨立的。例如ORDER BY x, y DESC 意思是說ORDER BY x ASC, y DESC,

不同于ORDER BY x DESC, y DESC。

一個_sort_expression_也可以是字段名或字段編號,如:

SELECT a + b AS sum, c FROM table1 ORDER BY sum;
SELECT a, max(b) FROM table1 GROUP BY a ORDER BY 1;

都按照第一個字段進行排序。

需要注意的是,輸出字段名必須是獨立的(不允許在表達式中使用)。

比如,下面的語句是錯誤的:

SELECT a + b AS sum, c FROM table1 ORDER BY sum + c;     -- 錯誤的

這樣的限制主要是為了避免歧義。另外,如果某個排序表達式能夠同時匹配輸出字段名和表表達式中的字段名, 也會導致歧義(此時使用輸出字段名)。

當然,這種情況僅在你使用了AS 重命名輸出字段并且恰好與其它表的字段同名的時候才會發(fā)生。

ORDER BY可以應用于UNION, INTERSECT,EXCEPT 組合的計算結(jié)果,

不過在這種情況下,只允許按照字段的名字或編號進行排序,而不允許按照表達式進行排序。

Notes

[1] 事實上,PostgreSQL使用默認的B-tree操作符類 為表達式的數(shù)據(jù)類型確定ASC和DESC排序順序。

一般來說,數(shù)據(jù)類型將被轉(zhuǎn)換為適合于 <和 >操作符進行排序。但是對于用戶自定義的數(shù)據(jù)類型可以不必如此。

補充:postgresql多列綜合排序

一、需求

最近做項目遇到一個需求:對數(shù)據(jù)按照更新時間和創(chuàng)建時間進行綜合排序,即對數(shù)據(jù)的操作時間進行排序,但是數(shù)據(jù)表中沒有操作時間這個字段,需要根據(jù)更新時間和創(chuàng)建時間進行處理。

更新時間存在時,按照更新時間排序,更新時間不存在時,使用創(chuàng)建時間排序,最后更新時間和創(chuàng)建時間一起排序。

用數(shù)據(jù)舉例說明:

原始數(shù)據(jù):

想要的排序結(jié)果:

二、postgresql 排序語法

SELECT column_list
  FROM table_name
  ORDER BY sort_expression1 [ASC | DESC] [NULLS { FIRST | LAST }]
       [, `sort_expression2` [ASC | DESC] [NULLS { FIRST | LAST }] ...]

說明:

sort_expression 可以是列名,也可以是列的表達式.如可以將不同列相加后排序:

SELECT a, b FROM table1 ORDER BY a + b, c;

ASC | DESC 是可選的,按升序或者降序排列結(jié)果集。默認是 ASC。

NULLS FIRST 和 NULLS LAST 選項可以決定在排序操作中在 null 值之前還是之后。默認情況下,空值大于任何非空值;也就是說,DESC 排序默認是 NULLS FIRST,否則為 NULLS LAST。

三、使用排序 SQL 嘗試獲取得到想要的排序結(jié)果

先按照 modify_time 和 create_time 列降序排列

sql:

select id, name, creator, create_time, modifier, modify_time from tb_exam order by modify_time desc, create_time desc;

運行結(jié)果:

分析:

從運行結(jié)果看出 modify_time 為 null 的數(shù)據(jù)排列在前,不符合需求。

改變 null 值的位置

sql:

select id, name, creator, create_time, modifier, modify_time from tb_exam order by modify_time desc nulls last, create_time desc;

運行結(jié)果:

分析:

modify_time 為 null 的數(shù)據(jù)雖然在后面了,但排序結(jié)果并不符合要求。沒有達到修改時間和創(chuàng)建時間綜合排序的效果。

由此可見,使用基本的排序語法達不到兩列綜合排序的效果,可使用 case when 實現(xiàn)自定義排序規(guī)則。

自定義排序規(guī)則

sql:

select id, name, creator, create_time, modifier, modify_time from tb_exam order by
case
 when modify_time is null then create_time
 when modify_time < create_time then create_time
 else modify_time
end
desc;

運行結(jié)果:

分析:

從運行結(jié)果可知,該 sql 的排序結(jié)果符合需求,實現(xiàn)了 modify_time 和 create_time 的綜合排序。

結(jié)論:

可使用 case when 在一定程度上實現(xiàn)自定義排序規(guī)則,實現(xiàn)多列數(shù)據(jù)綜合排序。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關文章

  • PostgreSQL LIKE 大小寫實例

    PostgreSQL LIKE 大小寫實例

    這篇文章主要介紹了PostgreSQL LIKE 大小寫實例,具有很好的參考價值,希望對大家有所幫助。 一起跟隨小編過來看看吧
    2021-01-01
  • pgsql查詢優(yōu)化之模糊查詢實例詳解

    pgsql查詢優(yōu)化之模糊查詢實例詳解

    這篇文章主要給大家介紹了關于pgsql查詢優(yōu)化之模糊查詢的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用pgsql具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-07-07
  • PostgreSQL HOT與PHOT有哪些區(qū)別

    PostgreSQL HOT與PHOT有哪些區(qū)別

    這篇文章主要介紹了PostgreSQL8.3版本開始就引入的HOT機制與PHOT使用區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-09-09
  • postgresql 13.1 insert into select并行查詢的實現(xiàn)

    postgresql 13.1 insert into select并行查詢的實現(xiàn)

    這篇文章主要介紹了解決postgresql insert into select無法使用并行查詢的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 解決postgresql 自增id作為key重復的問題

    解決postgresql 自增id作為key重復的問題

    這篇文章主要介紹了解決postgresql 自增id作為key重復的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • GP如何查詢并刪除重復數(shù)據(jù)

    GP如何查詢并刪除重復數(shù)據(jù)

    這篇文章主要介紹了GP如何查詢并刪除重復數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • 詳解PostgreSql數(shù)據(jù)庫對象信息及應用

    詳解PostgreSql數(shù)據(jù)庫對象信息及應用

    這篇文章主要介紹了PostgreSql數(shù)據(jù)庫對象信息及應用,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • PostgreSQL數(shù)據(jù)庫事務插入刪除及更新操作示例

    PostgreSQL數(shù)據(jù)庫事務插入刪除及更新操作示例

    這篇文章主要為大家介紹了PostgreSQL事務的插入刪除及更新操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪
    2022-04-04
  • 如何在PostgreSQL中創(chuàng)建只讀權(quán)限和讀寫權(quán)限的賬號

    如何在PostgreSQL中創(chuàng)建只讀權(quán)限和讀寫權(quán)限的賬號

    一個良好的賬號管理策略對于數(shù)據(jù)庫的安全和數(shù)據(jù)的完整性至關重要,通過為不同的用戶設置適當?shù)臋?quán)限,可以確保他們只能訪問他們需要的數(shù)據(jù),并防止對敏感數(shù)據(jù)的意外或惡意訪問,本文介紹在 PostgreSQL中創(chuàng)建只讀權(quán)限和讀寫權(quán)限的賬號的步驟和方法,感興趣的朋友一起看看吧
    2023-08-08
  • Postgresql開啟遠程訪問的步驟全紀錄

    Postgresql開啟遠程訪問的步驟全紀錄

    postgre一般默認為本地連接,不支持遠程訪問,所以如果要開啟遠程訪問,需要更改安裝文件的配置。下面這篇文章主要給大家介紹了關于Postgresql開啟遠程訪問的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2018-03-03

最新評論