搜尋
首頁資料庫Oracleoracle的函數有哪些
oracle的函數有哪些Mar 16, 2022 pm 05:36 PM
oracle函數

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
什么是oracle asm什么是oracle asmApr 18, 2022 pm 04:16 PM

oracle asm指的是“自动存储管理”,是一种卷管理器,可自动管理磁盘组并提供有效的数据冗余功能;它是做为单独的Oracle实例实施和部署。asm的优势:1、配置简单、可最大化推动数据库合并的存储资源利用;2、支持BIGFILE文件等。

oracle怎么查询所有索引oracle怎么查询所有索引May 13, 2022 pm 05:23 PM

方法:1、利用“select*from user_indexes where table_name=表名”语句查询表中索引;2、利用“select*from all_indexes where table_name=表名”语句查询所有索引。

Oracle怎么查询端口号Oracle怎么查询端口号May 13, 2022 am 10:10 AM

在Oracle中,可利用lsnrctl命令查询端口号,该命令是Oracle的监听命令;在启动、关闭或重启oracle监听器之前可使用该命令检查oracle监听器的状态,语法为“lsnrctl status”,结果PORT后的内容就是端口号。

oracle全角怎么转半角oracle全角怎么转半角May 13, 2022 pm 03:21 PM

在oracle中,可以利用“TO_SINGLE_BYTE(String)”将全角转换为半角;“TO_SINGLE_BYTE”函数可以将参数中所有多字节字符都替换为等价的单字节字符,只有当数据库字符集同时包含多字节和单字节字符的时候有效。

oracle怎么删除sequenceoracle怎么删除sequenceMay 13, 2022 pm 03:35 PM

在oracle中,可以利用“drop sequence sequence名”来删除sequence;sequence是自动增加数字序列的意思,也就是序列号,序列号自动增加不能重置,因此需要利用drop sequence语句来删除序列。

oracle怎么查询数据类型oracle怎么查询数据类型May 13, 2022 pm 04:19 PM

在oracle中,可以利用“select ... From all_tab_columns where table_name=upper('表名') AND owner=upper('数据库登录用户名');”语句查询数据库表的数据类型。

oracle查询怎么不区分大小写oracle查询怎么不区分大小写May 10, 2022 pm 05:45 PM

方法:1、利用“LOWER(字段值)”将字段转为小写,或者利用“UPPER(字段值)”将字段转为大写;2、利用“REGEXP_LIKE(字符串,正则表达式,'i')”,当参数设置为“i”时,说明进行匹配不区分大小写。

Oracle怎么修改sessionOracle怎么修改sessionMay 13, 2022 pm 05:06 PM

方法:1、利用“alter system set sessions=修改后的数值 scope=spfile”语句修改session参数;2、修改参数之后利用“shutdown immediate – startup”语句重启服务器即可生效。

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.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

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

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境