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中文網其他相關文章!