婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 關(guān)于PostgreSQL 行排序的實(shí)例解析

關(guān)于PostgreSQL 行排序的實(shí)例解析

熱門標(biāo)簽:電銷機(jī)器人能補(bǔ)救房產(chǎn)中介嗎 濟(jì)南外呼網(wǎng)絡(luò)電話線路 江蘇400電話辦理官方 地圖標(biāo)注要花多少錢 天津開發(fā)區(qū)地圖標(biāo)注app 廣州電銷機(jī)器人公司招聘 移動(dòng)外呼系統(tǒng)模擬題 400電話申請(qǐng)客服 電話機(jī)器人怎么換人工座席

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

如果沒(méi)有排序,那么行將以不可預(yù)測(cè)的順序返回(實(shí)際順序?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 是任何可用于選擇列表的表達(dá)式,可以將不同列相加減乘除后排序,例如:

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

如果指定了多個(gè)排序表達(dá)式,那么僅在前面的表達(dá)式排序相等的情況下才使用后面的表達(dá)式做進(jìn)一步排序。

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

類似的是,降序是以gt;操作符來(lái)判斷的。

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

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

注意,排序選項(xiàng)對(duì)于每個(gè)排序列是相對(duì)獨(dú)立的。例如ORDER BY x, y DESC 意思是說(shuō)ORDER BY x ASC, y DESC,

不同于ORDER BY x DESC, y DESC。

一個(gè)_sort_expression_也可以是字段名或字段編號(hào),如:

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

都按照第一個(gè)字段進(jìn)行排序。

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

比如,下面的語(yǔ)句是錯(cuò)誤的:

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

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

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

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

不過(guò)在這種情況下,只允許按照字段的名字或編號(hào)進(jìn)行排序,而不允許按照表達(dá)式進(jìn)行排序。

Notes

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

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

補(bǔ)充:postgresql多列綜合排序

一、需求

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

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

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

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

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

二、postgresql 排序語(yǔ)法

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

說(shuō)明:

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

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

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

NULLS FIRST 和 NULLS LAST 選項(xiàng)可以決定在排序操作中在 null 值之前還是之后。默認(rèn)情況下,空值大于任何非空值;也就是說(shuō),DESC 排序默認(rèn)是 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;

運(yùn)行結(jié)果:

分析:

從運(yùn)行結(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;

運(yùn)行結(jié)果:

分析:

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

由此可見,使用基本的排序語(yǔ)法達(dá)不到兩列綜合排序的效果,可使用 case when 實(shí)現(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;

運(yùn)行結(jié)果:

分析:

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

結(jié)論:

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

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

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

標(biāo)簽:溫州 濮陽(yáng) 海西 辛集 寶雞 榆林 昭通 杭州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《關(guān)于PostgreSQL 行排序的實(shí)例解析》,本文關(guān)鍵詞  關(guān)于,PostgreSQL,行,排序,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《關(guān)于PostgreSQL 行排序的實(shí)例解析》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于關(guān)于PostgreSQL 行排序的實(shí)例解析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲最大成人综合| 丝袜a∨在线一区二区三区不卡| 国内精品久久久久影院色| 久久久99精品久久| 欧美在线观看18| 亚洲国产欧美一区二区三区丁香婷| 在线91免费看| 日本一不卡视频| 婷婷中文字幕综合| 欧美激情在线一区二区| 欧美午夜精品一区| 精品亚洲免费视频| 精品国产凹凸成av人导航| 成人免费电影视频| 毛片av一区二区三区| 亚洲日本一区二区三区| 国产高清不卡一区| 国产不卡视频一区| 日韩国产精品91| 日韩一区二区三区电影在线观看| 精品日韩成人av| 在线看一区二区| 蜜臀久久久久久久| 亚洲一区在线视频观看| 欧美大胆一级视频| a在线欧美一区| 久久se这里有精品| 一区二区三区日韩欧美精品| 天天亚洲美女在线视频| 亚洲视频免费在线| 国产午夜亚洲精品羞羞网站| 欧美日韩成人综合天天影院| 日韩免费高清av| 欧美无乱码久久久免费午夜一区| 国产精品一区免费在线观看| 天堂va蜜桃一区二区三区漫画版| 中文字幕一区二区三区在线不卡 | 日韩免费看的电影| av在线播放一区二区三区| 91精品国产福利| 欧美视频在线不卡| 高清国产一区二区| 日韩国产高清在线| 久久久精品综合| 亚洲欧洲精品天堂一级| 久久人人超碰精品| 6080亚洲精品一区二区| 日本不卡中文字幕| 美女www一区二区| 亚洲一二三专区| 国产精品麻豆视频| 欧美日韩一区三区| 色香蕉成人二区免费| 一区二区三区四区高清精品免费观看| 色中色一区二区| 成人福利视频网站| 成人午夜电影网站| 久久精品国产亚洲aⅴ | 紧缚捆绑精品一区二区| 亚洲国产精品一区二区www| 中文字幕在线观看一区| 国产精品婷婷午夜在线观看| 精品欧美乱码久久久久久1区2区| 欧美精品视频www在线观看| 在线视频国内一区二区| 在线亚洲人成电影网站色www| 91网站黄www| 在线观看国产日韩| 欧美在线影院一区二区| 欧美日韩精品欧美日韩精品一| 色婷婷av一区二区三区大白胸| 九色|91porny| 国产精品一区二区视频| 国产精品综合网| 欧美tickling网站挠脚心| 99视频在线观看一区三区| 成人免费视频一区| 91亚洲精品久久久蜜桃网站 | 久久网这里都是精品| 国产色爱av资源综合区| 久久精品视频一区二区三区| 久久久久国产成人精品亚洲午夜| 91福利小视频| 欧洲国内综合视频| 国产69精品久久久久毛片| 日韩av中文在线观看| 看片的网站亚洲| 国产在线精品一区二区夜色 | 日韩美一区二区三区| 日本韩国欧美三级| 韩国午夜理伦三级不卡影院| 国产一区不卡精品| 成人av免费在线| 色婷婷香蕉在线一区二区| 免费成人在线网站| 亚洲午夜国产一区99re久久| 中文字幕不卡在线播放| 国产在线一区观看| 欧美日韩在线播放三区四区| 激情成人综合网| 国产福利91精品| 久久国产福利国产秒拍| 偷拍自拍另类欧美| 久久成人av少妇免费| 免费人成黄页网站在线一区二区| 国产乱妇无码大片在线观看| 91一区一区三区| 正在播放一区二区| 国产成人精品影视| 99久久精品国产网站| 欧美日韩国产美| 精品国产乱码久久久久久免费| 欧美一区二区三区视频免费 | 成人免费视频caoporn| 亚洲大片精品永久免费| 91麻豆精品国产91久久久使用方法| 亚洲免费观看在线观看| 欧美日本韩国一区| 国产亚洲综合性久久久影院| 欧美亚洲丝袜传媒另类| 国产成人久久精品77777最新版本| 国产日韩高清在线| 555www色欧美视频| 欧美午夜不卡在线观看免费| 国产一区二区三区久久悠悠色av| 亚洲精品在线网站| 久久激情五月婷婷| 精品视频免费看| 日韩亚洲欧美成人一区| 国产精品自产自拍| 国产精品一区在线观看你懂的| 色94色欧美sute亚洲13| 欧美一级高清片在线观看| 亚洲少妇中出一区| 欧美在线三级电影| 天堂av在线一区| 精品国产电影一区二区 | 国内精品久久久久影院一蜜桃| 久久午夜羞羞影院免费观看| 成人午夜视频在线| 亚洲午夜私人影院| 日韩欧美久久一区| 成人黄色大片在线观看| 亚洲美女在线一区| 欧美一级黄色大片| 懂色av中文字幕一区二区三区| 亚洲女同一区二区| 91精品国产91久久综合桃花| 久久成人免费网站| 中文字幕一区二区不卡| 欧美美女一区二区| 国产不卡高清在线观看视频| 亚洲自拍偷拍欧美| 日韩一区二区电影在线| 成人av网站在线观看免费| 亚洲电影第三页| 欧美一区二区精品| 91国偷自产一区二区使用方法| 久久99精品视频| 亚洲少妇中出一区| 日韩女优电影在线观看| 不卡av免费在线观看| 日本视频一区二区三区| 国产精品久久久久久亚洲毛片| 欧美老肥妇做.爰bbww| 成人性生交大片免费看视频在线| 一区二区理论电影在线观看| 日韩欧美成人激情| 91精彩视频在线观看| 国产激情一区二区三区桃花岛亚洲| 亚洲免费av在线| 欧美一级生活片| 91精品办公室少妇高潮对白| 久久99精品国产91久久来源| 一区二区三区高清| 亚洲国产精品精华液2区45| 欧美日韩高清不卡| 99视频国产精品| 国产一区二区三区国产| 香蕉加勒比综合久久| 91视频一区二区三区| 国产一区美女在线| 亚洲国产精品久久一线不卡| 中文字幕高清不卡| 日韩欧美一二三| 欧美日韩视频在线一区二区| 99亚偷拍自图区亚洲| 国产一区二区三区黄视频| 国产精品久久久久久久久搜平片 | 中文字幕不卡一区| 69精品人人人人| 91精品福利在线一区二区三区 | 色天天综合久久久久综合片| 午夜精品一区二区三区免费视频| 久久99国产精品免费网站| 欧美日韩精品免费观看视频| 国产亚洲精品超碰| 国产在线视频一区二区三区| 欧美日韩亚洲不卡| 最新热久久免费视频|