搜尋
首頁資料庫Oracle歸納整理Oracle中常用函數

這篇文章為大家帶來了關於Oracle的相關知識,其中詳細講解了Oracle中常用函數,透過範例程式碼介紹,希望對大家的學習或工作具有一定的參考借鑒價值,希望對大家有幫助。

歸納整理Oracle中常用函數

推薦教學:《Oracle影片教學

oracle資料庫中主要使用兩種類型的函數:

1.  單行函數:操作一行數據,傳回一個結果

  • #常用的單行函數有:
  • 字串函數:對字串運算。
  • 數字函數:對數字進行計算,傳回一個數字。
  • 日期函數:對日期和時間進行處理。
  • 轉換函數:可以將一種資料型別轉換為另外一種資料型別。

2.  聚合函數(多行函數、分組函數、群組函數):操作多行數據,並傳回一個結果。例如 SUM

一、字串函數

字元函數接受字元參數,這些參數可以是表中的列,也可以是字串表達式。

常用的字元函數:

函數 #說明
ASCII(X) 傳回字元X的ASCII碼
CONCAT(X,Y) 連接字串X和Y
#INSTR(X,STR[,START][,N) 從X中尋找str,可以指定從start開始,也可以指定從n開始
LENGTH(X) 傳回X的長度
#LOWER(X) X轉換成小寫
UPPER(X) X轉換成大寫
#LTRIM(X[,TRIM_STR]) 把X的左截去trim_str字串,預設截去空格
RTRIM(X[,TRIM_STR]) 把X的右邊截去trim_str字串,缺省截去空格
TRIM([TRIM_STR  FROM]X) 把X的兩邊截去trim_str字串,缺省截斷空格
#REPLACE(X,old,new) 在X中尋找old,並替換成new
SUBSTR(X,start[,length]) 傳回X的字串,從start處開始,截取length個字符,缺省length,預設到結尾

上面各函數的例子:

範例 範例結果
#SELECT ASCII('a') FROM dual; #97
SELECT CONCAT('Hello','world') FROM dual; Helloworld
SELECT INSTR ('Hello world','or') FROM dual; 8
#SELECT LENGTH('Hello') FROM dual; #5
SELECT LOWER('Hello') FROM dual; hello
SELECT UPPER('hello') FROM dual; HELLO
SELECT LTRIM('=Hello=','=') FROM dual; Hello=
#SELECT RTRIM('=Hello=','=') FROM dual; =Hello
SELECT TRIM('='FROM'= Hello=') FROM dual; Hello
SELECT REPLACE('ABCDE','CD','AAA')FROM dual; ABAAAE
SELECT SUBSTR('ABCDE',2,3) FROM dual; BCD

二、數字函數

數字函數接受數字參數,參數可以來自表格中的一列,也可以是數字表達式。

##X除以Y的餘數MOD(8,3)=2POWER(X,Y)X的Y次方POWER( 2,3)=8ROUND(X[,Y])X在Y位四捨五入ROUND(3.456,2) =3.46SQRT(X)X的平方根SQRT(4)=2TRUNC(X[,Y])X在第Y位元截斷TRUNC(3.456,2)=3.45

說明:

1.ROUND(X[,Y]),四捨五入。

在缺省 y 時,預設 y=0;例如:ROUND(3.56)=4。

y 是正整數,就是四捨五入到小數點後 y 位。 ROUND(5.654,2)=5.65。

y 是負整數,四捨五入到小數點左邊|y|位。 ROUND(351.654,-2)=400。

2.TRUNC(x[,y]),直接截取,不四捨五入。

在預設省 y 時,預設 y=0;例如:TRUNC (3.56)=3。

Y是正整數,就是四捨五入到小數點後 y 位。 TRUNC (5.654,2)=5.65。

y 是負整數,四捨五入到小數點左邊|y|位。 TRUNC (351.654,-2)=300。

三、日期函數

日期函數對日期進行運算。常用的日期函數有:

1、ADD_MONTHS(d,n),在某一個日期 d 上,加上指定的月數 n,並傳回計算後的新日期。

d 表示日期,n 表示要加的月數。

範例:

SELECT SYSDATE,add_months(SYSDATE,5) FROM dual;

 

#2、LAST_DAY(d),傳回指定日期當月的最後一天。

例:

SELECT SYSDATE,last_day(SYSDATE) FROM dual;

 

#3、ROUND(d[,fmt]),回傳一個以fmt 為格式的四捨五入日期值, d 是日期, fmt 是格式

模型。預設 fmt 為 DDD,即月中的某一天。

  •   若 fmt 為「YEAR」則捨去某一年的 1 月 1 日,即前半年捨去,後半年作為下一年度。

  •   若 fmt 為「MONTH」則捨去某月的 1 日,即前月捨去,後半月為下一月。

  •   預設為“DDD”,即月中的某一天,最靠近的天,前半天捨去,後半天作為第二天。

  •   若 fmt 為「DAY」則捨入到最近的週的星期日,即上半週捨去,下半週作為下一個星期日。

例:

SELECT SYSDATE,ROUND(SYSDATE),ROUND(SYSDATE,'day'),

ROUND(SYSDATE,'month'),ROUND(SYSDATE,'year') FROM dual;

 

#與 ROUND 對應的函數時 TRUNC(d[,fmt])對日期的操作, TRUNC與 ROUND 非常相似,只是不對日期進行捨入,直接截取到對應格式的第一天。

4、EXTRACT(fmt FROM d),提取日期中的特定部分。

fmt 為:YEAR、MONTH、DAY、HOUR、MINUTE、SECOND。其中 YEAR、MONTH、DAY可以為 DATE 類型配對,也可以與 TIMESTAMP 類型相符;但是 HOUR、MINUTE、SECOND 必須與 TIMESTAMP 類型相符。

HOUR 配對的結果沒有加上時區,因此在中國運作的結果小 8 小時。

範例:

SELECT SYSDATE "date",

       EXTRACT(YEAR FROM SYSDATE)"year",

       EXTRACT(MONTH FROM SYSDATE)"month",

       EXTRACT(DAY FROM SYSDATE)"day",

       EXTRACT(HOUR FROM SYSTIMESTAMP)"hour",

       EXTRACT(MINUTE FROM SYSTIMESTAMP)"minute",

       EXTRACT(SECOND FROM SYSTIMESTAMP)"second"

FROM dual;

四、轉換函數

轉換函數將值從一種資料型別轉換為另一種資料型別。常見的轉換函數有:

1、TO_CHAR(d|n[,fmt])

把日期和數字轉換成製定格式的字串。 Fmt是格式化字串

程式碼示範:TO_CHAR對日期的處理

SELECT TO_CHAR(SYSDATE,'YYYY"年"MM"月"DD"日" HH24:MI:SS')"date" FROM dual;

 

程式碼解析:

#在格式化字串中,使用雙引號對非格式化字元進行引用

針對數字的格式化,格式化字元有:

函數 說明 範例
ABS(X) X的絕對值 ABS(-3)=3
#ACOS(X) X的反餘弦 ACOS(1)=0
COS(X) 餘弦 COS(1)=0.54030230586814
#CEIL(X) 大於或等於X的最小值 CEIL(5.4)=6
FLOOR(X) 小於或等於X的最大值 FLOOR(5.8)=5
#LOG(X,Y) X為底Y的對數 LOG(2,4)=2
#MOD(X,Y)
9.#,$##EEEE9.99EEEE
參數
#範例 說明
999 指定位置處顯示數字
9.9 指定位置傳回小數點
99,99 指定位置回傳一個逗號
$999 數字開頭傳回一個美元符號
###科學計數法表示#############L######L999######數位前加一個本地貨幣符號# ###########PR######999PR######如果數字式負數則用尖括號表示############

代码演示:TO_CHAR对数字的处理

SELECT TO_CHAR(-123123.45,'L9.9EEEEPR')"date" FROM dual;

 

2、TO_DATE(X,[,fmt])

把一个字符串以fmt格式转换成一个日期类型

3、TO_NUMBER(X,[,fmt])

把一个字符串以fmt格式转换为一个数字

代码演示:TO_NUM函数

SELECT TO_NUMBER('-$12,345.67','$99,999.99')"num" FROM dual;

 

五、其它单行函数

1、NVL(X,VALUE)

如果X为空,返回value,否则返回X

例:对工资是2000元以下的员工,如果没发奖金,每人奖金100元

代码演示:NVL函数

SELECT ENAME,JOB,SAL,NVL(COMM,100) FROM EMP WHERE SAL<2000;

-------------------------------------------------------------------

ENAME    JOB    SAL    NVL(COMM,100) 

SMITH    CLERK    800    100 

ALLEN    SALESMAN    1600    300 

WARD    SALESMAN    1250    500 

MARTIN    SALESMAN    1250    1400 

TURNER    SALESMAN    1500    50 

ADAMS    CLERK    1100    100 

JAMES    CLERK    950    100 

-------------------------------------------------------------------

7 rows selected

2、NVL2(x,value1,value2)

如果x非空,返回value1,否则返回value2

例:对EMP表中工资为2000元以下的员工,如果没有奖金,则奖金为200元,如果有奖金,则在原来的奖金基础上加100元

代码演示:NVL2函数

SELECT ENAME,JOB,SAL,NVL2(COMM,comm+100,200) "comm" FROM EMP WHERE SAL<2000;

-------------------------------------------------------------------

ENAME    JOB    SAL    comm 

SMITH    CLERK    800    200 

ALLEN    SALESMAN    1600    400 

WARD    SALESMAN    1250    600 

MARTIN    SALESMAN    1250    1500 

TURNER    SALESMAN    1500    150 

ADAMS    CLERK    1100    200 

JAMES    CLERK    950    200 

MILLER    CLERK    1300    200

-------------------------------------------------------------------------------------------------------

8 rows selected

六、聚合函数

聚合函数同时对一组数据进行操作,返回一行结果,比如计算一组数据的总和,平均值等。

名称 作用 语法
AVG 平均值 AVG(表达式)
SUM 求和 SUM(表达式)
MIN、MAX 最小值、最大值 MIN(表达式)、MAX(表达式)
COUNT 数据统计 COUNT(表达式)

例:求本月所有员工的基本工资总和

代码演示:sum函数

SELECT SUM(sal) FROM emp;

-------------------------------------------------------------------

SUM(SAL)

29025

例:求不同部门的平均工资

代码演示:AVG函数下的分组查询

SELECT DEPTNO,AVG(SAL) FROM EMP GROUP BY DEPTNO;

-------------------------------------------------------------------

DEPTNO    AVG(SAL)

---------    ----------

30    1566.66666

20     2175

10    2916.66666

推荐教程:《Oracle视频教程

以上是歸納整理Oracle中常用函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:脚本之家。如有侵權,請聯絡admin@php.cn刪除
甲骨文的目的:業務解決方案和數據管理甲骨文的目的:業務解決方案和數據管理Apr 13, 2025 am 12:02 AM

Oracle通過其產品和服務幫助企業實現數字化轉型和數據管理。 1)Oracle提供全面的產品組合,包括數據庫管理系統、ERP和CRM系統,幫助企業自動化和優化業務流程。 2)Oracle的ERP系統如E-BusinessSuite和FusionApplications,實現端到端業務流程自動化,提高效率並降低成本,但實施和維護成本較高。 3)OracleDatabase提供高並發和高可用性數據處理,但許可成本較高。 4)性能優化和最佳實踐包括合理使用索引和分區技術、定期數據庫維護及遵循編碼規範。

oracle建庫失敗怎麼刪除oracle建庫失敗怎麼刪除Apr 12, 2025 am 06:21 AM

Oracle建庫失敗後刪除失敗數據庫的步驟:使用sys用戶名連接目標實例使用DROP DATABASE刪除失敗數據庫查詢v$database確認數據庫已刪除

oracle怎麼循環創建游標oracle怎麼循環創建游標Apr 12, 2025 am 06:18 AM

Oracle 中,FOR LOOP 循環可動態創建游標, 步驟為:1. 定義游標類型;2. 創建循環;3. 動態創建游標;4. 執行游標;5. 關閉游標。示例:可循環創建游標,顯示前 10 名員工姓名和工資。

oracle視圖怎麼導出oracle視圖怎麼導出Apr 12, 2025 am 06:15 AM

可以通過 EXP 實用程序導出 Oracle 視圖:登錄 Oracle 數據庫。啟動 EXP 實用程序,指定視圖名稱和導出目錄。輸入導出參數,包括目標模式、文件格式和表空間。開始導出。使用 impdp 實用程序驗證導出。

oracle數據庫怎麼停止oracle數據庫怎麼停止Apr 12, 2025 am 06:12 AM

要停止 Oracle 數據庫,請執行以下步驟:1. 連接到數據庫;2. 優雅關機數據庫(shutdown immediate);3. 完全關機數據庫(shutdown abort)。

oracle日誌寫滿怎麼辦oracle日誌寫滿怎麼辦Apr 12, 2025 am 06:09 AM

Oracle 日誌文件寫滿時,可採用以下解決方案:1)清理舊日誌文件;2)增加日誌文件大小;3)增加日誌文件組;4)設置自動日誌管理;5)重新初始化數據庫。在實施任何解決方案前,建議備份數據庫以防數據丟失。

oracle動態sql怎麼創建oracle動態sql怎麼創建Apr 12, 2025 am 06:06 AM

可以通過使用 Oracle 的動態 SQL 來根據運行時輸入創建和執行 SQL 語句。步驟包括:準備一個空字符串變量來存儲動態生成的 SQL 語句。使用 EXECUTE IMMEDIATE 或 PREPARE 語句編譯和執行動態 SQL 語句。使用 bind 變量傳遞用戶輸入或其他動態值給動態 SQL。使用 EXECUTE IMMEDIATE 或 EXECUTE 執行動態 SQL 語句。

oracle死鎖怎麼辦oracle死鎖怎麼辦Apr 12, 2025 am 06:03 AM

Oracle 死鎖處理指南:識別死鎖:檢查日誌文件中的 "deadlock detected" 錯誤。查看死鎖信息:使用 GET_DEADLOCK 包或 V$LOCK 視圖獲取死鎖會話和資源信息。分析死鎖圖:生成死鎖圖以可視化鎖持有和等待情況,確定死鎖根源。回滾死鎖會話:使用 KILL SESSION 命令回滾會話,但可能導致數據丟失。中斷死鎖週期:使用 DISCONNECT SESSION 命令斷開會話連接,釋放持有的鎖。預防死鎖:優化查詢、使用樂觀鎖定、進行事務管理和定期

See all articles

熱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尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具