《Oracle 特色函數(shù)及復(fù)雜更新應(yīng)用》由會(huì)員分享,可在線閱讀,更多相關(guān)《Oracle 特色函數(shù)及復(fù)雜更新應(yīng)用(24頁珍藏版)》請?jiān)谘b配圖網(wǎng)上搜索。
1、Click to edit Master title style,Click to edit Master text styles,Second level,Third level,Fourth level,Fifth level,*,*,單擊此處編輯母版文本樣式,第二級,第三級,第四級,第五級,單擊此處編輯母版標(biāo)題樣式,*,單擊此處編輯母版文本樣式,第二級,第三級,第四級,第五級,*,單擊此處編輯母版標(biāo)題樣式,Oracle,特色函數(shù)及復(fù)雜更新應(yīng)用,目標(biāo),今天主要介紹一下日常操作中可能會(huì)用上,Oracle,的特色函數(shù),:,轉(zhuǎn)換函數(shù):,to_char,通用函數(shù):,nvl,、,nullif,、,n
2、vl2,、,coalesce,、,decode,日期函數(shù):,months_between,、,add_months,、,next_day,、,last_day,通過,Round,、,Trunc,函數(shù),操作日期,復(fù)雜的,Update Table,應(yīng)用,顯式數(shù)據(jù)類型轉(zhuǎn)換,NUMBER,CHARACTER,TO_CHAR,TO_NUMBER,DATE,TO_CHAR,TO_DATE,TO_CHAR,函數(shù)對日期的轉(zhuǎn)換,TO_CHAR(,date,format_model,),格式,:,必須包含在單引號中而且大小寫敏感。,可以包含任意的有效的日期格式。,可以使用,fm,去掉多余的空格或者前導(dǎo)零。,與日期
3、指用逗號隔開。,YYYY,日期格式的元素,YEAR,MM,MONTH,DY,DAY,2004,TWO THOUSAND AND FOUR,02,MON,MONDAY,JULY,MON,JUL,DD,02,練習(xí),如何用,SQL,語句返回以下格式,(假設(shè)今天是,2010-9-13,),2010,年,9,月,13,日,13/09/10,2010/9/13,2010,年的第,37,周,2010,年的第,256,天,2010,年的第,37,周星期一,TO_CHAR,函數(shù)對數(shù)字的轉(zhuǎn)換,下面是在,TO_CHAR,函數(shù)中經(jīng)常使用的幾種格式,:,TO_CHAR(,number,format_model,),9,
4、0,$,L,.,數(shù)字,零,美元符,本地貨幣符號,小數(shù)點(diǎn),千位符,練習(xí),怎樣把一個(gè)隨意的數(shù)字轉(zhuǎn)換成以下格式(小于一千萬):,235678.9851-235,678.99,235678.9851-,¥,235,678.99,8-,通用函數(shù),這些函數(shù)適用于任何數(shù)據(jù)類型,同時(shí)也適用于空值:,NVL(expr1,expr2),NVL2(expr1,expr2,expr3),NULLIF(expr1,expr2),COALESCE(expr1,expr2,.,expr,n,),NVL,函數(shù),將空值轉(zhuǎn)換成一個(gè)已知的值:,可以使用的數(shù)據(jù)類型有日期、字符、數(shù)字。,函數(shù)的一般形式,:,NVL(commission
5、_pct,0),NVL(hire_date,01-JAN-97),NVL(job_id,No Job Yet),NVL2,函數(shù),判斷值是否為空,如果值不為空則返回第一個(gè)表達(dá)式,否則返回第二個(gè)表達(dá)式:,可以使用的數(shù)據(jù)類型有日期、字符、數(shù)字。,函數(shù)的一般形式,:,NVL2(value,exp1,exp2),NULLIF 函數(shù),NULLIF(exp1,exp2),CASE WHEN exp1=exp2 THEN NULL ELSE exp1 END,比較兩個(gè)表達(dá)式,如果它們相等則返回空值,否則返回表達(dá)式一,注意:表達(dá)式一不能為空,COALESCE,函數(shù),COALESCE(exp1,exp2,expN
6、),COALESCE,返回表達(dá)式列表中第一個(gè)不為空的表達(dá)式,COALESCE(expr1,expr2),CASE WHEN expr1 IS NOT NULL THEN expr1 ELSE expr2 END,COALESCE(expr1,expr2,.,exprn),for n=3,CASE WHEN expr1 IS NOT NULL THEN expr1 ELSE COALESCE(expr2,.,exprn)END,CASE,表達(dá)式,在需要使用,IF-THEN-ELSE,邏輯時(shí),:,CASE,expr,WHEN,comparison_expr1,THEN,return_expr1,W
7、HEN,comparison_expr2,THEN,return_expr2,WHEN,comparison_exprn,THEN,return_exprn,ELSE,else_expr,END,DECODE(expr,comparison_expr1,return_expr1,comparison_expr2,return_expr2,comparison_exprn,return_exprn,else_expr),日期函數(shù),兩日期相差多少月,MONTHS_BETWEEN,ADD_MONTHS,NEXT_DAY,LAST_DAY,ROUND,TRUNC,加月份以日期,指定日期的下一天,一個(gè)月
8、中的最后一天,Round,日期,Truncate,日期,函數(shù),描述,練習(xí),-,日期運(yùn)算,得到2010-5-10至2010-9-13經(jīng)過了多少天,得到2010-5-10至2010-9-13經(jīng)過了多少個(gè)月,得到某個(gè)日期兩個(gè)月后的日期,得到某個(gè)日期這天后100天的日期,得到某個(gè)日期兩個(gè)月后的那個(gè)月的最后一天,高級更新操作,提出疑問,如何實(shí)現(xiàn)以下,SQL Server,中的,Update,操作,舉例,高級更新操作,提出疑問,有以下表結(jié)構(gòu),如何通過一個(gè)語句達(dá)到以下功能:,把,A,表的數(shù)據(jù)同步到,B,表,以,ID,字段為主鍵,如果,B,表中沒有,A,表的記錄,請插入,合并語句,按照指定的條件執(zhí)行插入或刪除
9、操作,如果滿足條件的行存在,執(zhí)行更新操作;否則執(zhí)行插入操作,:,避免多次重復(fù)執(zhí)行插入和刪除操作,提高效率而且使用方便,在數(shù)據(jù)倉庫應(yīng)用中經(jīng)常使用,合并語句的語法,可以使用,merge,語句,根據(jù)指定的條件進(jìn)行插入,或更新操作,MERGE INTO,table_name,table_alias,USING(,table|view|sub_query,),alias,ON(,join condition,),WHEN MATCHED THEN,UPDATE SET,col1=col_val1,col2=col2_val,WHEN NOT MATCHED THEN,INSERT(,column_lis
10、t,),VALUES(,column_values,);,MERGE INTO copy_emp c,USING employees e,ON(c.employee_id=e.employee_id),WHEN MATCHED THEN,UPDATE SET,c.first_name =e.first_name,c.last_name =e.last_name,.,c.department_id =e.department_id,WHEN NOT MATCHED THEN,INSERT VALUES(e.employee_id,e.first_name,e.last_name,e.email,
11、e.phone_number,e.hire_date,e.job_id,e.salary,mission_pct,e.manager_id,e.department_id);,合并語句舉例,在對表,COPY_EMP,使用,merge,語句,根據(jù)指定,的條件從表,EMPLOYEES,中插入或更新數(shù)據(jù)。,合并語句舉例,MERGE INTO copy_emp c,USING employees e,ON(c.employee_id=e.employee_id),WHEN MATCHED THEN,UPDATE SET,.,WHEN NOT MATCHED THEN,INSERT VALUES.;,S
12、ELECT*,FROM COPY_EMP;,no rows selected,SELECT*,FROM COPY_EMP;,20 rows selected,.,演講完畢,謝謝觀看!,內(nèi)容總結(jié),Oracle 特色函數(shù)及復(fù)雜更新應(yīng)用。通用函數(shù):nvl、nullif、nvl2、coalesce、decode??梢允褂?fm 去掉多余的空格或者前導(dǎo)零。如何用SQL語句返回以下格式(假設(shè)今天是2010-9-13)。13/09/10。2010/9/13。TO_CHAR(number,format_model)。235678.9851-235,678.99。235678.9851-¥235,678.99。8-??梢允褂玫臄?shù)據(jù)類型有日期、字符、數(shù)字。NVL(hire_date,01-JAN-97)。NVL(job_id,No Job Yet)。COALESCE(expr1,expr2)。有以下表結(jié)構(gòu),如何通過一個(gè)語句達(dá)到以下功能:。USING(table|view|sub_query)alias。ON(join condition)。col1=col_val1,