好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 關于PostgreSQL 行排序的實例解析

關于PostgreSQL 行排序的實例解析

熱門標簽:電銷機器人能補救房產中介嗎 濟南外呼網絡電話線路 江蘇400電話辦理官方 地圖標注要花多少錢 天津開發區地圖標注app 廣州電銷機器人公司招聘 移動外呼系統模擬題 400電話申請客服 電話機器人怎么換人工座席

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

如果沒有排序,那么行將以不可預測的順序返回(實際順序將取決于掃描和連接規劃類型和在磁盤上的順序,

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

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(降序)以設置排序方向。 升序先輸出小的數值,這里的"小"是以lt;操作符的角度定義的。

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

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 重命名輸出字段并且恰好與其它表的字段同名的時候才會發生。

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

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

Notes

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

一般來說,數據類型將被轉換為適合于 lt;和 gt;操作符進行排序。但是對于用戶自定義的數據類型可以不必如此。

補充:postgresql多列綜合排序

一、需求

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

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

用數據舉例說明:

原始數據:

想要的排序結果:

二、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 是可選的,按升序或者降序排列結果集。默認是 ASC。

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

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

先按照 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;

運行結果:

分析:

從運行結果看出 modify_time 為 null 的數據排列在前,不符合需求。

改變 null 值的位置

sql:

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

運行結果:

分析:

modify_time 為 null 的數據雖然在后面了,但排序結果并不符合要求。沒有達到修改時間和創建時間綜合排序的效果。

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

自定義排序規則

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;

運行結果:

分析:

從運行結果可知,該 sql 的排序結果符合需求,實現了 modify_time 和 create_time 的綜合排序。

結論:

可使用 case when 在一定程度上實現自定義排序規則,實現多列數據綜合排序。

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

您可能感興趣的文章:
  • Postgresql自定義函數詳解
  • PostgreSQL的中文拼音排序案例
  • Postgresql排序與limit組合場景性能極限優化詳解
  • 自定義函數實現單詞排序并運用于PostgreSQL(實現代碼)

標簽:溫州 濮陽 海西 辛集 寶雞 榆林 昭通 杭州

巨人網絡通訊聲明:本文標題《關于PostgreSQL 行排序的實例解析》,本文關鍵詞  關于,PostgreSQL,行,排序,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《關于PostgreSQL 行排序的實例解析》相關的同類信息!
  • 本頁收集關于關于PostgreSQL 行排序的實例解析的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 亚洲国产伦理| 真人性做爰无遮A片免费什么软件| 女明星们的yin荡生活小说| 亚洲女同志videos| 国产精品免费一级在线观看| 三上悠亚ssni绝顶を教え込ま| 亲孑亲子伦inin??X国产 | 久久精品中文字幕极品| 黄色黄色片| 男高H漫画网站在线阅读| 古代闺秀被强行糟蹋H文章| 亚洲免费在线视频播放| 波多野结衣无删减版电影办公室 | 日本极品人妻videossex| 国产精品黄网站免费观看| 狠狠色噜噜狠狠狠狠色综合网| 九九国产精品九九| 欧美午夜电影一区二区三区 | 床戏视频| ?网曝吃瓜黑料泄密在线一二| 把女人弄特爽黄a大片 剧情简介| 年轻护士夜放荡护士| 私人IMAX情侣影院家庭影院| 久久国产欧美日韩精品免费| 四川一级毛片女老板全黄| 在线精品国产第一页| 爽爽窝窝午夜精品一区二区| 国产91??在线播放九色000| 国产精品人人做人人爽人人添| 嫂子的羞耻心| 办公室下被扒奶罩吮奶头App| 麻豆 白洁少妇在线播放| 又弹又肥的一线天馒头| 男人猛烈进入女人下部视频| 超清国产粉嫩456在线免播放| 6066yyy午夜精品无码| 美女把衣服脱光光| 五指山市| 罗志祥多人运动在线观看| 国产乱婬AV国产888草莓Av| 狂揉吃奶胸高潮视频在线|