ORACLE日期時間函數大全 (三)

ORACLE日期時間函數大全 (三)
2010-05-11 13:38
三. 字符函數(可用於字面字符或數據庫列)

1,字符串截取
select substr('abcdef',1,3) from dual
數據庫

2,查找子串位置
select instr('abcfdgfdhd','fd') from dual
函數

3,字符串鏈接
select 'HELLO'||'hello world' from dual;
spa

4, 1)去掉字符串中的空格
select ltrim(' abc') s1,
rtrim('zhang ') s2,
trim(' zhang ') s3 from dual
2)去掉前導和後綴
select trim(leading 9 from 9998767999) s1,
trim(trailing 9 from 9998767999) s2,
trim(9 from 9998767999) s3 from dual;

5,返回字符串首字母的Ascii值
select ascii('a') from dual
code

6,返回ascii值對應的字母
select chr(97) from dual
事務

7,計算字符串長度
select length('abcdef') from dual
ci

8,initcap(首字母變大寫) ,lower(變小寫),upper(變大寫)
select lower('ABC') s1,
upper('def') s2,
initcap('efg') s3
from dual;
字符串

9,Replace
select replace('abc','b','xy') from dual;
it

10,translate
select translate('abc','b','xx') from dual; -- x是1位
table

11,lpad [左添充] rpad [右填充](用於控制輸出格式)
select lpad('func',15,'=') s1, rpad('func',15,'-') s2 from dual;
select lpad(dname,14,'=') from dept;
class

12, decode[實現if ..then 邏輯] 注:第一個是表達式,最後一個是不知足任何一個條件的值
select deptno,decode(deptno,10,'1',20,'2',30,'3','其餘') from dept;
例:
select seed,account_name,decode(seed,111,1000,200,2000,0) from t_userInfo//若是seed爲111,則取1000;爲200,取2000;其它取0
select seed,account_name,decode(sign(seed-111),1,'big seed',-1,'little seed','equal seed') from t_userInfo//若是seed>111,則顯示大;爲200,則顯示小;其它則顯

示相等

13 case[實現switch ..case 邏輯]
SELECT CASE X-FIELD
WHEN X-FIELD < 40 THEN 'X-FIELD 小於 40'
WHEN X-FIELD < 50 THEN 'X-FIELD 小於 50'
WHEN X-FIELD < 60 THEN 'X-FIELD 小於 60'
ELSE 'UNBEKNOWN'
END
FROM DUAL

注:CASE語句在處理相似問題就顯得很是靈活。當只是須要匹配少許數值時,用Decode更爲簡潔。

四.數字函數
1,取整函數(ceil 向上取整,floor 向下取整)
select ceil(66.6) N1,floor(66.6) N2 from dual;

2, 取冪(power) 和求平方根(sqrt)
select power(3,2) N1,sqrt(9) N2 from dual;

3,求餘
select mod(9,5) from dual;

4,返回固定小數位數 (round:四捨五入,trunc:直接截斷)
select round(66.667,2) N1,trunc(66.667,2) N2 from dual;

5,返回值的符號(正數返回爲1,負數爲-1)
select sign(-32),sign(293) from dual;

五.轉換函數
1,to_char()[將日期和數字類型轉換成字符類型]
1) select to_char(sysdate) s1,
to_char(sysdate,'yyyy-mm-dd') s2,
to_char(sysdate,'yyyy') s3,
to_char(sysdate,'yyyy-mm-dd hh12:mi:ss') s4,
to_char(sysdate, 'hh24:mi:ss') s5,
to_char(sysdate,'DAY') s6
from dual;
2) select sal,to_char(sal,'$99999') n1,to_char(sal,'$99,999') n2 from emp

2, to_date()[將字符類型轉換爲日期類型]
insert into emp(empno,hiredate) values(8000,to_date('2004-10-10','yyyy-mm-dd'));

3, to_number() 轉換爲數字類型
select to_number(to_char(sysdate,'hh12')) from dual; //以數字顯示的小時數

六.其餘函數
1.user:
返回登陸的用戶名稱
select user from dual;

2.vsize:
返回表達式所需的字節數
select vsize('HELLO') from dual;

3.nvl(ex1,ex2):  
ex1值爲空則返回ex2,不然返回該值自己ex1(經常使用)
例:若是僱員沒有佣金,將顯示0,不然顯示佣金
select comm,nvl(comm,0) from emp;

4.nullif(ex1,ex2):
值相等返空,不然返回第一個值
例:若是工資和佣金相等,則顯示空,不然顯示工資
select nullif(sal,comm),sal,comm from emp;

5.coalesce:  
返回列表中第一個非空表達式
select comm,sal,coalesce(comm,sal,sal*10) from emp;

6.nvl2(ex1,ex2,ex3) :
若是ex1不爲空,顯示ex2,不然顯示ex3
如:查看有佣金的僱員姓名以及他們的佣金
  select nvl2(comm,ename,') as HaveCommName,comm from emp;


七.分組函數
max min avg count sum
1,整個結果集是一個組
1) 求部門30 的最高工資,最低工資,平均工資,總人數,有工做的人數,工種數量及工資總和
select max(ename),max(sal),
min(ename),min(sal),
avg(sal),
count(*) ,count(job),count(distinct(job)) ,
sum(sal) from emp where deptno=30;
2, 帶group by 和 having 的分組
1)按部門分組求最高工資,最低工資,總人數,有工做的人數,工種數量及工資總和
select deptno, max(ename),max(sal),
min(ename),min(sal),
avg(sal),
count(*) ,count(job),count(distinct(job)) ,
sum(sal) from emp group by deptno;

2)部門30的最高工資,最低工資,總人數,有工做的人數,工種數量及工資總和
select deptno, max(ename),max(sal),
min(ename),min(sal),
avg(sal),
count(*) ,count(job),count(distinct(job)) ,
sum(sal) from emp group by deptno having deptno=30;

3, stddev 返回一組值的標準誤差
select deptno,stddev(sal) from emp group by deptno;
variance 返回一組值的方差差
select deptno,variance(sal) from emp group by deptno;

4, 帶有rollup和cube操做符的Group By
rollup 按分組的第一個列進行統計和最後的小計
cube 按分組的全部列的進行統計和最後的小計
select deptno,job ,sum(sal) from emp group by deptno,job;
select deptno,job ,sum(sal) from emp group by rollup(deptno,job);
cube 產生組內全部列的統計和最後的小計
select deptno,job ,sum(sal) from emp group by cube(deptno,job);

8、臨時表只在會話期間或在事務處理期間存在的表.臨時表在插入數據時,動態分配空間create global temporary table temp_dept(dno number,dname varchar2(10))on commit delete rows;insert into temp_dept values(10,'ABC');commit;select * from temp_dept; --無數據顯示,數據自動清除on commit preserve rows:在會話期間表一直能夠存在(保留數據)on commit delete rows:事務結束清除數據(在事務結束時自動刪除表的數據)

相關文章
相關標籤/搜索