欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

sql語句中臨時表使用實例詳解

 更新時間:2023年02月16日 11:27:01   作者:機智大袁  
當(dāng)需要的結(jié)果需要經(jīng)過多次處理后才能最終得到我們需要的結(jié)果時,就可以使用臨時表,這里臨時表就起到了一個中間處理的作用,實現(xiàn)了分步處理,簡化了問題,這篇文章主要介紹了sql語句中臨時表使用方法,需要的朋友可以參考下

一、臨時表實現(xiàn)分步處理

1.概述

當(dāng)需要的結(jié)果需要經(jīng)過多次處理后才能最終得到我們需要的結(jié)果時,就可以使用臨時表,這里臨時表就起到了一個中間處理的作用,實現(xiàn)了分步處理,簡化了問題。

2.實例

2.1表格結(jié)構(gòu)

pln_order_pool_detail(表名)

2.2需求

需要得到訂單平均交付周期、最大交付周期、最小交付周期,為了實現(xiàn)這一需求,首先我們要求出每個訂單的交付周期,其次我們需要將這些訂單的交付周期求其平均值。

2.3sql語句

SELECT
    AVG( leadTime ) avgLeadTime,
    MAX( leadTime ) maxLeadTime,
    MIN( leadTime ) minLeadTime
FROM
    ( SELECT DATEDIFF(reality_deliver_time,create_time) AS leadTime FROM  pln_order_pool  WHERE order_state = 'finish' ) a

2.4sql語句解析

其中 SELECT DATEDIFF(reality_deliver_time,create_time) AS leadTime FROM  pln_order_pool  WHERE order_state = 'finish' 是求出每個訂單的交付周期作為臨時表,每個訂單的交付周期即狀態(tài)(order_state)為'finish'的訂單的實際交付時間(reality_deliver_time)減去該訂單的創(chuàng)建時間(create_time)

DATEDIFF(reality_deliver_time,create_time):該函數(shù)表示實際交付日期(reality_deliver_time)與創(chuàng)建日期(create_time)的間隔,且結(jié)果是以天數(shù)進行返回

 AVG( leadTime ):將臨時表中的交付周期通過AVG函數(shù)求出平均交付周期

MAX( leadTime):將臨時表中的交付周期通過MAX函數(shù)求出最大交付周期

MIN( leadTime):將臨時表中的交付周期通過MIN函數(shù)求出最小交付周期

二、臨時表實現(xiàn)分層處理

1、概述

在實際開發(fā)中經(jīng)常會碰到一個字段下存儲的結(jié)果不同,而我又需要對這兩個結(jié)果進行處理得到最終的結(jié)果,此時如果沒有臨時表我們就可能需要寫兩個sql語句分別得到結(jié)果,然后在后端進行運算得到最終需要的結(jié)果。

2、實例

也許上面的概述表述并不清楚,現(xiàn)在用一個實例來說明。

像這樣的一個表結(jié)構(gòu),我想要計算2022年8月9號這一天的計劃完成率,那就需要計算該日期的計劃數(shù)和計劃完成數(shù)的比值,也就是計算該日期的實出對應(yīng)的數(shù)量與該日期的計劃對應(yīng)的數(shù)量的比值,但是上面的表結(jié)構(gòu)中計劃與實出都在type一個字段下,我又該如何將where條件設(shè)置為type等于“計劃”求出計劃數(shù),同時又將where條件設(shè)置為type等于“實出”求出實際完成的數(shù)量呢?

2.1表結(jié)構(gòu)

plan(表名)

2.2需求

求出2022年8月9號一天的計劃完成率

2.3sql語句

SELECT
	planNums,
	finishNums,
	IFNULL( ROUND( finishNums / planNums * 100, 2 ), 0 ) finishRate 
FROM
	( SELECT SUM( num ) planNums FROM plan WHERE type = '計劃' AND date = '2022-08-09') a,
	( SELECT SUM( num ) finishNums FROM plan WHERE type = '實出' AND date = '2022-08-09') b

2.4sql語句解析

針對上述的問題,我們使用臨時表就可以完美的解決,根據(jù)條件的不同我們建立兩個臨時表,分別記錄當(dāng)天的計劃總數(shù)和當(dāng)天的實際完成的數(shù)量,實現(xiàn)分層處理,最后我們再將臨時表中的數(shù)據(jù)進行運算就可以得到當(dāng)天的計劃完成率。

SELECT SUM( num ) planNums FROM plan WHERE type = '計劃' AND date = '2022-08-09'

 此句求出2022年8月9號的計劃總數(shù)臨時表

SELECT SUM( num ) finishNums FROM plan WHERE type = '實出' AND date = '2022-08-09'

此句求出2022年8月9號的實際完成總數(shù)臨時表

IFNULL(ROUND(finishNums/planNums*100,2),0):此函數(shù)用于排除臨時表中計劃總數(shù)為null的情況,若ROUND(finishNums/planNums*100,2)為空,則返回值為0,否則返回值就是ROUND(finishNums/planNums*100,2)

ROUND(finishNums/planNums*100,2):此函數(shù)為四舍五入函數(shù),將finishNums/planNums*100計算的結(jié)果保留兩位小數(shù)

注意:臨時表一定需要起別名,否則就會報錯

到此這篇關(guān)于sql語句中臨時表使用方法的文章就介紹到這了,更多相關(guān)sql臨時表使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論