freepeople性欧美熟妇, 色戒完整版无删减158分钟hd, 无码精品国产vα在线观看DVD, 丰满少妇伦精品无码专区在线观看,艾栗栗与纹身男宾馆3p50分钟,国产AV片在线观看,黑人与美女高潮,18岁女RAPPERDISSSUBS,国产手机在机看影片

正文內(nèi)容

oracle100個常用函數(shù)(編輯修改稿)

2025-06-11 23:18 本頁面
 

【文章內(nèi)容簡介】 ENAME SAL 10 KING 5000 10 CLARK 2450 10 MILLER 1300 20 SCOTT 3000 20 FORD 3000 20 JONES 2975 20 ADAMS 1100 20 SMITH 800 30 BLAKE 2850 30 ALLEN 1600 30 TURNER 1500 30 WARD 1250 30 MARTIN 1250 30 JAMES 950 70. pl/sql中的case語句 select (case when DUMMY=39。X39。 then 0 else 1 end) as flag from dual。 case的第1種用法: case col when 39。a39。 then 1 when 39。b39。 then 2 else 0 end 這種用法跟decode一樣沒什么區(qū)別 case的第2種用法: case when score 60 then 39。d39。 when score =60 and score 70 then 39。c39。 when score =70 and score 80 then 39。b39。 else 39。a39。 end 71. NVL(expr1, expr2) 72. NVL(expr1, expr2)expr1為NULL,返回expr2;不為NULL,返回expr1。注意兩者的類型要一致 NVL2 (expr1, expr2, expr3) expr1不為NULL,返回expr2;為NULL,返回expr3。expr2和expr3類型不同的話,expr3會轉(zhuǎn)換為expr2的類型 NULLIF (expr1, expr2) 相等返回NULL,不等返回expr1 ,分析函數(shù)用于計算基于組的某種聚合值,它和聚合函數(shù)的不同之處是對于每個組返回多行, 而聚合函數(shù)對于每個組只返回一行。 常用的分析函數(shù)如下所列: row_number() over(partition by ... order by ...) rank() over(partition by ... order by ...) dense_rank() over(partition by ... order by ...) count() over(partition by ... order by ...) max() over(partition by ... order by ...) min() over(partition by ... order by ...) sum() over(partition by ... order by ...) avg() over(partition by ... order by ...) first_value() over(partition by ... order by ...) last_value() over(partition by ... order by ...) lag() over(partition by ... order by ...) lead() over(partition by ... order by ...) 下面例子中使用的表來自O(shè)racle自帶的HR用戶下的表,如果沒有安裝該用戶,可以在SYS用戶下運行 $ORACLE_HOME/demo/schema/human_resources/。 除本文內(nèi)容外,你還可參考: ROLLUP與CUBE [url][/url] 分析函數(shù)使用例子介紹:[url][/url] 本文如果未指明,缺省是在HR用戶下運行例子。 開窗函數(shù)的的理解: 開窗函數(shù)指定了分析函數(shù)工作的數(shù)據(jù)窗口大小,這個數(shù)據(jù)窗口大小可能會隨著行的變化而變化,舉例如下: over(order by salary) 按照salary排序進行累計,order by是個默認的開窗函數(shù) over(partition by deptno)按照部門分區(qū) over(order by salary range between 50 preceding and 150 following) 每行對應(yīng)的數(shù)據(jù)窗口是之前行幅度值不超過50,之后行幅度值不超過150 over(order by salary rows between 50 preceding and 150 following) 每行對應(yīng)的數(shù)據(jù)窗口是之前50行,之后150行 over(order by salary rows between unbounded preceding and unbounded following) 每行對應(yīng)的數(shù)據(jù)窗口是從第一行到最后一行,等效: over(order by salary range between unbounded preceding and unbounded following) 主要參考資料:《expert oneonone》 Tom Kyte 《Oracle9i SQL Reference》第6章 oh 2007312 09:1973. AVG 功能描述:用于計算一個組和數(shù)據(jù)窗口內(nèi)表達式的平均值。 SAMPLE:下面的例子中列c_mavg計算員工表中每個員工的平均薪水報告,該平均值由當前員工和與之具有相同經(jīng)理的前一個和后一個三者的平均數(shù)得來; SELECT manager_id, last_name, hire_date, salary, AVG(salary) OVER (PARTITION BY manager_id ORDER BY hire_date ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING) AS c_mavg FROM employees。 MANAGER_ID LAST_NAME HIRE_DATE SALARY C_MAVG 100 Kochhar 21SEP89 17000 17000 100 De Haan 13JAN93 17000 15000 100 Raphaely 07DEC94 11000 100 Kaufling 01MAY95 7900 100 Hartstein 17FEB96 13000 100 Weiss 18JUL96 8000 100 Russell 01OCT96 14000 74. CORR 功能描述:返回一對表達式的相關(guān)系數(shù),它是如下的縮寫: COVAR_POP(expr1,expr2)/STDDEV_POP(expr1)*STDDEV_POP(expr2)) 從統(tǒng)計上講,相關(guān)性是變量之間關(guān)聯(lián)的強度,變量之間的關(guān)聯(lián)意味著在某種程度 上一個變量的值可由其它的值進行預測。通過返回一個1~1之間的一個數(shù), 相關(guān) 系數(shù)給出了關(guān)聯(lián)的強度,0表示不相關(guān)。 SAMPLE:下例返回1998年月銷售收入和月單位銷售的關(guān)系的累積系數(shù)(本例在SH用戶下運行) SELECT , CORR (SUM(), SUM()) OVER (ORDER BY ) as CUM_CORR FROM sales s, times t WHERE = AND calendar_year = 1998 GROUP BY ORDER BY 。 CALENDAR_MONTH_NUMBER CUM_CORR 1 2 1 3 .994309382 4 .852040875 5 .846652204 6 .871250628 7 .910029803 8 .917556399 9 .920154356 10 .86720251 11 .844864765 12 .903542662 75. COVAR_POP 功能描述:返回一對表達式的總體協(xié)方差。 SAMPLE:下例CUM_COVP返回定價和最小產(chǎn)品價格的累積總體協(xié)方差 SELECT product_id, supplier_id, COVAR_POP(list_price, min_price) OVER (ORDER BY product_id, supplier_id) AS CUM_COVP, COVAR_SAMP(list_price, min_price) OVER (ORDER BY product_id, supplier_id) AS CUM_COVS FROM product_information p WHERE category_id = 29 ORDER BY product_id, supplier_id。 PRODUCT_ID SUPPLIER_ID CUM_COVP CUM_COVS 1774 103088 0 1775 103087 1794 103096 1825 103093 2004 103086 2005 103086 1815 2416 103088 . . 76. COVAR_SAMP 功能描述:返回一對表達式的樣本協(xié)方差 SAMPLE:下例CUM_COVS返回定價和最小產(chǎn)品價格的累積樣本協(xié)方差 SELECT product_id, supplier_id, COVAR_POP(list_price, min_price) OVER (ORDER BY product_id, supplier_id) AS CUM_COVP, COVAR_SAMP(list_price, min_price) OVER (ORDER BY product_id, supplier_id) AS CUM_COVS FROM product_information p WHERE category_id = 29 ORDER BY product_id, supplier_id。 PRODUCT_ID SUPPLIER_ID CUM_COVP CUM_COVS 1774 103088 0 1775 103087 1794 103096 1825 103093 2004 103086 2005 103086 1815 2416 103088 77. COUNT 功能描述:對一組內(nèi)發(fā)生的事情進行累積計數(shù),如果指定*或一些非空常數(shù),count將對所有行計數(shù),如果指定一個表達式,count 返回表達式非空賦值的計數(shù),當有相同值出現(xiàn)時,這些相等的值都會被納入被計算的值;可以使用DISTINCT來記錄去掉一組中完全 相同的數(shù)據(jù)后出現(xiàn)的行數(shù)。 SAMPLE:下面例子中計算每個員工在按薪水排序中當前行附近薪水在[n50,n+150]之間的行數(shù),n表示當前行的薪水 例如,Philtanker的薪水2200,排在他之前的行中薪水大于等于220050的有1行,排在他之后的行中薪水小于等于2200+150的行 沒有,所以count計數(shù)值t3為2(包括自己當前行);t2值相當于小于等于當前行的SALARY值的所有行數(shù) SELECT last_name, salary, COUNT(*) OVER () AS t1, COUNT(*) OVER (ORDER BY salary) AS t2, COUNT(*) OVER (ORDER BY salary RANGE BETWEEN 50 PRECEDING AND 150 FOLLOWING) AS t3 FROM employees。 LAST_NAME SALARY CNT1 CNT2 CNT3 Olson 2100 107 1 3 Markle 2200 107 3 2 Philtanker 2200 107 3 2 Landry 2400 107 5 8 Gee 2400 107 5 8 Colmenares 2500 107 11 10 Patel 2500 107 11 10 . . 78. CUME_DIST 功能描述:計算一行在組中的相對位置,CUME_DIST總是返回大于0、小于或等于1的數(shù),該數(shù)表示該行在N行中的位置。例如, 在一個3行的組中,返回的累計分布值為1/2/3/3 SAMPLE:下例中計算每個工種的員工按薪水排序依次累積出現(xiàn)的分布百分比 SELECT job_id, last_name, salary, CUME_DIST() OVER (PARTITION BY job_id ORDER BY salary) AS cume_dist FROM employees WHERE job_id LIKE 39。PU%39。 JOB_ID LAST_NAME S
點擊復制文檔內(nèi)容
公司管理相關(guān)推薦
文庫吧 www.dybbs8.com
備案圖片鄂ICP備17016276號-1