oracle的函數有:1、字串函數,包括ASCII()、CONCAT()等;2、數字函數,包括ABS()、COS()等;3、日期函數,包括EXTRACT( )、ROUND()等;4、轉換函數,包括TO_CHAR()、TO_DATE()等。
本教學操作環境:Windows7系統、Oracle 11g版、Dell G3電腦。
Oracle SQL語句中經常使用到Oracle自帶的函數,這些函數豐富了SQL的語言功能,為Oracle SQL提供了更多的操作性。 Oracle函數可以接受零個或多個輸入參數,並傳回一個輸出結果。 Oracle 資料庫中主要使用兩種類型的函數:
1、單行函數:當每個函數套用在表格的記錄中時,只能輸入一行中的列值作為輸入參數(或常數),並且傳回一個結果。
例如1:MOD(X,Y) 是求餘函數,傳回的X除以Y的餘數,其中X和Y可以是列值,也可以是常數。
例如2:TO_CHAR(X,'YYYYMMDD')是時間型別轉字串的函數,其中X可以是行中某一時間型別(date)的列,也可以是時間型別的常數。
常用的單行函數大致以下幾類:
字串函數:對字串進行運算,例如:TO_CHAR()、SUBSTR()、DECODE()等等。
數值函數:對數值進行計算或操作,傳回一個數字。例如:ABS()、MOD()、ROUND()等等。
轉換函數:將一個資料型別轉換成另一個型別:例如:TO_CHAR()、TO_NUMBER()、TO_DATE()等等。
日期函數:對時間和日期進行操作的函數。例如:TRUNC()、SYSDATE()、ADD_MONTHS()等等。
2、聚合函數:聚合函數同時可以對多行資料進行操作,並傳回一個結果。例如 SUM(x)傳回結果集中 x 列的總和。
一、字串函數
字元函數接受字元參數,這些參數可以是表格中的列,也可以是字串表達式。
常用的字元函數:
函數 |
|
#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 | |
#ABAAAE | ||
BCD |
函數 |
||
X的絕對值 | ABS(-3) =3 | |
#X的反餘弦 | ACOS(1)=0 | |
餘弦 | COS(1)=0.54030230586814 | |
#大於或等於X的最小值 | CEIL(5.4)=6 | |
##小於或等於X的最大值 | FLOOR(5.8)=5 | |
X為底Y的對數 | #LOG(2,4)=2 |
|
X除以Y的餘數 | MOD(8, 3)=2 | |
X的Y次方 | POWER(2,3)=8 | |
X在第Y位四捨五入 |
ROUND(3.456,2)=3.46 | |
X的平方根 | SQRT(4)=2 |
說明:
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;
程式碼解析:
#在格式化字串中,使用雙引號對非格式化字元進行引用
針對數字的格式化,格式化字元有:
參數 |
範例 |
說明 |
9 |
#999 |
指定位置處顯示數字 |
. |
9.9 |
指定位置傳回小數點 |
#, |
99,99 |
指定位置傳回一個逗號 |
#$999 |
數字開頭傳回一個美元符號 |
|
EEEE |
9.99EEEE |
科學計數法表示 |
L |
||
##L999 |
數字前面加上一個本地貨幣符號 |
PR |
代码演示: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函数
SQL> 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函数
SQL> SELECT ENAME,JOB,SAL,NVL2(COMM,comm+100,200) "comm" 2 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函数
SQL> SELECT SUM(sal) FROM emp; ------------------------------------------------------------------- SUM(SAL) 29025
例:求不同部门的平均工资
代码演示:AVG函数下的分组查询
SQL> SELECT DEPTNO,AVG(SAL) FROM EMP GROUP BY DEPTNO; ------------------------------------------------------------------- DEPTNO AVG(SAL) --------- ---------- 30 1566.66666 20 2175 10 2916.66666
推荐教程:《Oracle教程》
以上是oracle的函數有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Oracle的客戶群體廣泛且多樣化,涵蓋金融服務、醫療保健、零售與電子商務及製造業等多個領域。 1)在金融服務中,OracleFLEXCUBE提昇運營效率和數據安全;2)在醫療保健中,OracleHealthSciencesClinicalDevelopment加速新藥研發;3)在零售與電子商務中,OracleRetail和OracleCDP實現個性化客戶體驗;4)在製造業中,OracleERPCloud優化供應鏈管理。

Oracle 中的觸發器是用於在特定事件(插入、更新或刪除)觸發後自動執行操作的存儲過程。它們用於各種場景,包括數據驗證、審核和數據維護。創建觸發器時,需要指定觸發器名稱、關聯表、觸發事件和触發時間。有兩種類型的觸發器:BEFORE 觸發器在操作之前觸發,而 AFTER 觸發器在操作之後觸發。例如,BEFORE INSERT 觸發器可確保插入行的年齡列不為負。

重命名 Oracle 表名的兩種方法:使用 SQL 語句:ALTER TABLE <舊表名> RENAME TO <新表名>;使用 PL/SQL 語句:EXECUTE IMMEDIATE 'ALTER TABLE ' || :old_table_name || ' RENAME TO ' || :new_table_name;

Oracle 提供了以下回退已提交數據庫更改的方法:使用 ROLLBACK 語句立即撤銷所有未提交的更改。通過數據庫管理工具界面操作。使用 Oracle Flashback 技術返回到特定時間點並還原數據,需啟用閃回日誌記錄。

Oracle中查看索引是否已重建的方法:DBA_INDEXES視圖:查看REBUILT值(YES/NO);ALL_INDEXES視圖:查看STATUS值(VALID/UNUSABLE);V$INDEX_STATISTICS視圖:查看NUM_REBUILDS值,指示索引重建次數。

Oracle 升級失敗後,按照以下步驟還原系統:終止恢復,切換到恢復模式。使用恢復命令回滾數據文件。打開數據庫並確認數據文件已安裝,恢復 redo 日誌。如果控製文件損壞,重新創建它。以完全恢復模式重新打開數據庫。驗證還原,確認數據和對象完好。如果在還原期間創建了回滾段,請將其回滾。

要修改過期的 Oracle 數據庫密碼,請按照以下步驟操作:1. 退出所有會話;2. 以 SYSDBA 權限連接數據庫;3. 執行 ALTER USER 命令修改密碼;4. 使用新密碼重新連接;5. 執行查詢確認密碼已修改。

Oracle 中的轉義字符用於指示特殊字符或控制序列,包括行連接、字符串定界符、換行符、回車符、製表符和退格符。轉義字符處理通常涉及在字符串中轉義特殊字符、使用 | 連接多行字符串,以及使用反斜杠轉義轉義字符本身。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

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

Atom編輯器mac版下載
最受歡迎的的開源編輯器