首頁 >資料庫 >Oracle >oracle的函數有哪些

oracle的函數有哪些

青灯夜游
青灯夜游原創
2022-03-16 17:36:4844404瀏覽

oracle的函數有:1、字串函數,包括ASCII()、CONCAT()等;2、數字函數,包括ABS()、COS()等;3、日期函數,包括EXTRACT( )、ROUND()等;4、轉換函數,包括TO_CHAR()、TO_DATE()等。

oracle的函數有哪些

本教學操作環境: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 REPLACE(' ABCDE','CD','AAA')FROM dual;#ABAAAESELECT SUBSTR('ABCDE ',2,3) FROM dual;BCD

二、數字函數

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

範例

範例結果

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

ABS(X)X的絕對值ABS(-3) =3ACOS(X)#X的反餘弦ACOS(1)=0COS(X)餘弦COS(1)=0.54030230586814CEIL(X)#大於或等於X的最小值CEIL(5.4)=6FLOOR(X)LOG(X ,Y)#MOD(X,Y)POWER(X,Y)#ROUND(X[,Y])SQRT(X )

函數

##小於或等於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

#####################################################################################################################################################################################。 ##TRUNC(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;

 

程式碼解析:

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

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

PR

參數

範例

說明

9

#999

指定位置處顯示數字

.

9.9

指定位置傳回小數點

#,

99,99

指定位置傳回一個逗號

#$999

數字開頭傳回一個美元符號

EEEE

9.99EEEE

科學計數法表示

L

##L999

數字前面加上一個本地貨幣符號

######################################### ###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函数

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

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