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

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

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

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

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

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

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

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


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

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

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

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

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

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境