這篇文章為大家帶來了關於Oracle的相關知識,其中詳細講解了Oracle中常用函數,透過範例程式碼介紹,希望對大家的學習或工作具有一定的參考借鑒價值,希望對大家有幫助。
推薦教學:《Oracle影片教學》
oracle資料庫中主要使用兩種類型的函數:
1. 單行函數:操作一行數據,傳回一個結果
2. 聚合函數(多行函數、分組函數、群組函數):操作多行數據,並傳回一個結果。例如 SUM
字元函數接受字元參數,這些參數可以是表中的列,也可以是字串表達式。
常用的字元函數:
函數 | #說明 |
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 |
SELECT REPLACE('ABCDE','CD','AAA')FROM dual; | ABAAAE |
SELECT SUBSTR('ABCDE',2,3) FROM dual; | BCD |
數字函數接受數字參數,參數可以來自表格中的一列,也可以是數字表達式。
函數 | 說明 | 範例 |
ABS(X) | X的絕對值 | ABS(-3)=3 |
#ACOS(X) | X的反餘弦 | ACOS(1)=0 |
COS(X) | 餘弦 | COS(1)=0.54030230586814 |
#CEIL(X) | 大於或等於X的最小值 | CEIL(5.4)=6 |
FLOOR(X) | 小於或等於X的最大值 | FLOOR(5.8)=5 |
#LOG(X,Y) | X為底Y的對數 | LOG(2,4)=2 |
#MOD(X,Y) | ##X除以Y的餘數MOD(8,3)=2 | |
X的Y次方 | POWER( 2,3)=8 | |
X在Y位四捨五入 | ROUND(3.456,2) =3.46 | |
X的平方根 | SQRT(4)=2 | |
X在第Y位元截斷 | TRUNC(3.456,2)=3.45 |
參數 | ||
#範例 | 說明 | |
999 | 指定位置處顯示數字 | |
9.9 | 指定位置傳回小數點 | |
99,99 | 指定位置回傳一個逗號 | |
$999 | 數字開頭傳回一個美元符號 | ##EEEE |
代码演示: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函数
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函数
SELECT ENAME,JOB,SAL,NVL2(COMM,comm+100,200) "comm" 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函数
SELECT SUM(sal) FROM emp;
-------------------------------------------------------------------
SUM(SAL)
29025
例:求不同部门的平均工资
代码演示:AVG函数下的分组查询
SELECT DEPTNO,AVG(SAL) FROM EMP GROUP BY DEPTNO;
-------------------------------------------------------------------
DEPTNO AVG(SAL)
--------- ----------
30 1566.66666
20 2175
10 2916.66666
推荐教程:《Oracle视频教程》
以上是歸納整理Oracle中常用函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!