目錄
Oracle ORDER BY子句的範例
首頁 資料庫 Oracle oracle怎麼將查詢結果排序

oracle怎麼將查詢結果排序

Jan 13, 2022 am 11:33 AM
oracle

在oracle中,可以使用「SELECT」語句和「ORDER BY」子句來進行查詢排序,可依升序或降序對一列或多列的查詢結果集進行排序,語法「SELECT 欄位名FROM 資料表名ORDER BY 欄位名[ASC|DESC]」。

oracle怎麼將查詢結果排序

本教學操作環境:Windows7系統、Oracle 11g版、Dell G3電腦。

在oracle中,可以使用「SELECT」語句和「ORDER BY」子句來進行查詢排序。

在Oracle中,表中是以非指定順序儲存行資料記錄的,它不管行插入資料庫的順序如何。若要依列以升序或降序查詢行記錄,必須明確指示Oracle資料庫要如何去排序。

例如,您可能想要按名稱的字母順序列出所有客戶,或按照從最低到最高信用限額的順序顯示所有客戶。

要將查詢的資料排序,請如下將ORDER BY子句加入SELECT語句中。

ORDER BY子句可以升序或降序對一列或多列的結果集進行排序。

語法:

SELECT
    字段名,
FROM
    table_name
ORDER BY
    字段名 [ASC | DESC] [NULLS FIRST | NULLS LAST]
登入後複製

要按列排序結果集,可以在ORDER BY子句之後列出該列。

依照列名是一個排序順序,可以是:

  • #ASC 表示依升序排序

  • #DESC 表示依降序排序

預設情況下,無論是否指定ASCORDER BY子句都按升序對行進行排序。如果要按降序對行進行排序,請明確使用DESC

NULLS FIRST在非NULL#值之前放置NULL值,NULLS LAST在非NULL值之後放置NULL值。

ORDER BY子句可以依照多列對資料進行排序,每列可能有不同的排序順序。

請注意,ORDER BY子句總是SELECT語句中的最後一個子句。

Oracle ORDER BY子句的範例

下面將使用範例資料庫中的customers表格進行示範。

oracle怎麼將查詢結果排序

以下語句從客戶(customers)表中擷取客戶的:name, addresscredit limit

SELECT name, address, credit_limit FROM customers;
登入後複製

執行上面查詢語句,得到以下結果-

oracle怎麼將查詢結果排序

正如截圖中所看到的,行記錄的順序是未指定的。

1、按列排序行範例

要依照字母順序排列客戶名稱,請使用下列語句:

SELECT name,address,credit_limit
FROM customers
ORDER BY name ASC;
登入後複製

執行上面範例程式碼,得到以下結果-

oracle怎麼將查詢結果排序

ASC指示Oracle按升序對行進行排序。但是ASC是可選的,如果省略,則在預設情況下,ORDER BY子句按指定的列按升序對行進行排序。

因此,下面的表達式:

ORDER BY name ASC
登入後複製

等效於-

ORDER BY name
登入後複製

要按字母順序降序排列客戶名稱,請在ORDER BY子句中的列名之後明確使用DESC,如下所示:

SELECT name, address, credit_limit
FROM customers
ORDER BY name DESC;
登入後複製

執行上面查詢語句,得到以下結果-

oracle怎麼將查詢結果排序

2、按多個列排序行範例

要對多列進行排序,可以用逗號分隔ORDER BY子句中的每列。

請參閱範例資料庫中的以下聯絡人(contacts)表格。

例如,要按first_name進行按升序排序,並按降序對last_name列進行排序,請使用下列語句:

SELECT first_name, last_name
FROM contacts
ORDER BY first_name, last_name DESC;
登入後複製

執行上面範例程式碼,可以看到如下結果-

oracle怎麼將查詢結果排序

從上面截圖可以看到,contact_id91311這兩筆記錄的first_name的值相同,last_name的值是以降序來排列的。

在這個範例中,Oracle首先按first_name升序對行進行排序,以建立初始結果集。然後Oracle依降序對last_name排序初始結果集。

看到類似下面的結果如下:

oracle怎麼將查詢結果排序

在上面的這個結果:

  • 首先,按first_name升序排序。
  • 其次,如果两个名字相同,按last_name降序排列,如Daniel GlassDaniel CostnerDianne SenDianne DerekDoretha TylerDorotha Wong

3、按列位置排序行示例

不需要指定用于排序数据的列名称。如果您愿意,可以使用ORDER BY子句中列的位置。

请参考下语句 -

SELECT name, credit_limit,address
FROM customers
ORDER BY 2 DESC, 1;
登入後複製

在这个例子中,name列的位置是1credit_limit列的位置是2。相当于以下查询语句 -

SELECT name, credit_limit,address
FROM customers
ORDER BY credit_limit DESC, name;
登入後複製

ORDER BY子句中,使用这些列位置来指示Oracle对行进行排序。

4、用NULL值排序行的示例

请参阅示例数据库中的以下地区(locations)表:

oracle怎麼將查詢結果排序

以下语句按城市(city)和州(state)检索位置并对其进行排序:

SELECT country_id, city, state
FROM locations 
ORDER BY state DESC;
登入後複製

执行上面查询语句,得到以下结果 -

oracle怎麼將查詢結果排序

state列有NULL值,这意味着state数据与某些城市(例如:Beijing, HiroshimaLondon)无关。

当使用非NULL值对混合NULL进行排序时,Oracle允许指定哪个应该首先出现。

例如,以下语句按升序对state列进行排序,并首先将NULL值放置在前面。

SELECT country_id, city, state
FROM
    locations
ORDER BY
    state ASC NULLS FIRST;
登入後複製

要放置NULL值在后面,可以使用NULLS LAST,如下面的语句所示:

SELECT country_id, city, state
FROM
    locations
ORDER BY
    state ASC NULLS LAST;
登入後複製

执行上面示例查询语句,得到以下结果:

oracle怎麼將查詢結果排序

5、按函数或表达式排序数据

ORDER BY子句可在一列上应用一个函数,例如字符串函数,数学函数等,并按函数的结果对数据进行排序。

例如,以下语句使用ORDER BY子句中的UPPER()函数来区分客户名称的大小写:

SELECT customer_id, name
FROM customers
ORDER BY UPPER( name );
登入後複製

执行上面查询语句,得到以下结果 -

oracle怎麼將查詢結果排序

推荐教程:《Oracle教程

以上是oracle怎麼將查詢結果排序的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

oracle如何查表空間大小 oracle如何查表空間大小 Apr 11, 2025 pm 08:15 PM

要查詢 Oracle 表空間大小,請遵循以下步驟:確定表空間名稱,方法是運行查詢:SELECT tablespace_name FROM dba_tablespaces;查詢表空間大小,方法是運行查詢:SELECT sum(bytes) AS total_size, sum(bytes_free) AS available_space, sum(bytes) - sum(bytes_free) AS used_space FROM dba_data_files WHERE tablespace_

oracle數據庫如何導入 oracle數據庫如何導入 Apr 11, 2025 pm 08:06 PM

數據導入方法:1. 使用 SQLLoader 實用程序:準備數據文件、創建控製文件、運行 SQLLoader;2. 使用 IMP/EXP 工具:導出數據、導入數據。提示:1. 大數據集推薦 SQL*Loader;2. 目標表應存在,列定義匹配;3. 導入後需驗證數據完整性。

如何在oracle中創建表 如何在oracle中創建表 Apr 11, 2025 pm 08:00 PM

創建 Oracle 表涉及以下步驟:使用 CREATE TABLE 語法指定表名、列名、數據類型、約束和默認值。表名應簡潔、描述性,且不超過 30 個字符。列名應描述性,數據類型指定列中存儲的數據類型。 NOT NULL 約束確保列中不允許使用空值,DEFAULT 子句可指定列的默認值。 PRIMARY KEY 約束標識表的唯一記錄。 FOREIGN KEY 約束指定表中的列引用另一個表中的主鍵。請參見示例表 students 的創建,其中包含主鍵、唯一約束和默認值。

Oracle安裝失敗如何卸載 Oracle安裝失敗如何卸載 Apr 11, 2025 pm 08:24 PM

Oracle 安裝失敗的卸載方法:關閉 Oracle 服務,刪除 Oracle 程序文件和註冊表項,卸載 Oracle 環境變量,重新啟動計算機。若卸載失敗,可使用 Oracle 通用卸載工具手動卸載。

oracle如何查看實例名 oracle如何查看實例名 Apr 11, 2025 pm 08:18 PM

在 Oracle 中查看實例名的方法有三種:命令行中使用 "sqlplus" 和 "select instance_name from v$instance;" 命令。在 SQL*Plus 中使用 "show instance_name;" 命令。通過操作系統的任務管理器、Oracle Enterprise Manager 或檢查環境變量 (Linux 上的 ORACLE_SID)。

oracle如何去重查詢 oracle如何去重查詢 Apr 11, 2025 pm 07:33 PM

Oracle 提供多種去重查詢方法:DISTINCT 關鍵字返回每列的唯一值。 GROUP BY 子句對結果分組並返回每個分組的非重複值。 UNIQUE 關鍵字用於創建僅包含唯一行的索引,查詢該索引將自動去重。 ROW_NUMBER() 函數分配唯一數字並過濾出僅包含第 1 行的結果。 MIN() 或 MAX() 函數可返回數字列的非重複值。 INTERSECT 運算符返回兩個結果集的公共值(無重複項)。

oracle視圖如何加密 oracle視圖如何加密 Apr 11, 2025 pm 08:30 PM

Oracle 視圖加密允許您加密視圖中的數據,從而增強敏感信息安全性。步驟包括:1) 創建主加密密鑰 (MEk);2) 創建加密視圖,指定要加密的視圖和 MEk;3) 授權用戶訪問加密視圖。加密視圖工作原理:當用戶查詢加密視圖時,Oracle 使用 MEk 解密數據,確保只有授權用戶可以訪問可讀數據。

oracle如何獲取時間 oracle如何獲取時間 Apr 11, 2025 pm 08:09 PM

在 Oracle 中獲取時間有以下方法:CURRENT_TIMESTAMP:返回當前系統時間,精確到秒。 SYSTIMESTAMP:比 CURRENT_TIMESTAMP 更準確,精確到納秒。 SYSDATE:返回當前系統日期,不含時間部分。 TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS'): 將當前系統日期和時間轉換為特定格式。 EXTRACT:從時間值中提取特定部分,如年份、月份或小時。

See all articles