2017-09-25 510 views
0

enter image description here我有一個表格中有以下數據,我試圖從表格中獲取最大值和最小值列。如果它是一列,我可以使用列的最大/最小值,但在這裏我是比較表中的所有列。我需要的是添加新列以存儲最大和最小數據。從表中列的最大值和最小值

而且將只有一個行的表提前

create table 
#test (column1 int, column2 int , column3 int , column4 int ,column5 int,column6 int) 

insert into #test 
values(89, 103,87,67,86,56) 

select * from #test 

--drop table #test 

感謝。

+0

您可以取消轉換序列(https://technet.microsoft.com/en-us/library/ms177410(v=sql.105).aspx),然後取最大值/最小值 – Jeremy

回答

2

最簡單的方法就是交叉應用列的最小值/最大值。例如對於:

SELECT * 
FROM #test t 
CROSS APPLY (
    SELECT MAX(val), MIN(val) 
    FROM (VALUES (t.column1), (t.column2), (t.column3), (t.column4), (t.column5), (t.column6)) AS c(val) 
) AS c(maxvalue, minvalue); 
0

使用VALUES方法unpivot的數據,然後reaggravating它將使一個更清晰的語法,但它確實會帶來成本的性能(不可怕,但它的存在)。使用CASE表達式是有點更麻煩,但在語法部門,尤其是如果有很多列來進行評估,但你不會發生同樣的性能損失...

SELECT 
    t.column1, t.column2, t.column3, t.column4, t.column5, t.column6, 
    MinValue = CASE 
        WHEN t.column1 <= t.column2 AND t.column1 <= t.column3 AND t.column1 <= t.column4 AND t.column1 <= t.column5 AND t.column1 <= t.column6 THEN t.column1 
        WHEN t.column2 <= t.column1 AND t.column2 <= t.column3 AND t.column2 <= t.column4 AND t.column2 <= t.column5 AND t.column2 <= t.column6 THEN t.column2 
        WHEN t.column3 <= t.column1 AND t.column3 <= t.column2 AND t.column3 <= t.column4 AND t.column3 <= t.column5 AND t.column3 <= t.column6 THEN t.column3 
        WHEN t.column4 <= t.column1 AND t.column4 <= t.column2 AND t.column4 <= t.column3 AND t.column4 <= t.column5 AND t.column4 <= t.column6 THEN t.column4 
        WHEN t.column5 <= t.column1 AND t.column5 <= t.column2 AND t.column5 <= t.column3 AND t.column5 <= t.column4 AND t.column5 <= t.column6 THEN t.column5 
        ELSE t.column6 
       END, 
    MaxValue = CASE 
        WHEN t.column1 >= t.column2 AND t.column1 >= t.column3 AND t.column1 >= t.column4 AND t.column1 >= t.column5 AND t.column1 >= t.column6 THEN t.column1 
        WHEN t.column2 >= t.column1 AND t.column2 >= t.column3 AND t.column2 >= t.column4 AND t.column2 >= t.column5 AND t.column2 >= t.column6 THEN t.column2 
        WHEN t.column3 >= t.column1 AND t.column3 >= t.column2 AND t.column3 >= t.column4 AND t.column3 >= t.column5 AND t.column3 >= t.column6 THEN t.column3 
        WHEN t.column4 >= t.column1 AND t.column4 >= t.column2 AND t.column4 >= t.column3 AND t.column4 >= t.column5 AND t.column4 >= t.column6 THEN t.column4 
        WHEN t.column5 >= t.column1 AND t.column5 >= t.column2 AND t.column5 >= t.column3 AND t.column5 >= t.column4 AND t.column5 >= t.column6 THEN t.column5 
        ELSE t.column6 
       END 
FROM 
    #test t; 

結果...

column1  column2  column3  column4  column5  column6  MinValue MaxValue 
----------- ----------- ----------- ----------- ----------- ----------- ----------- ----------- 
89   103   87   67   86   56   56   103 
0

我發現這個解決方案here

SELECT 
    column1 
    ,column2 
    ,column3 
    ,column4 
    ,column5 
    ,column6 
    ,(SELECT MAX(MaxValue) 
     FROM (VALUES (column1),(column2),(column3), (column4), (column5), (column6)) AS [Values](MaxValue)) 
    AS MaxValue 
    ,(SELECT MIN(MinValue) 
     FROM (VALUES (column1),(column2),(column3), (column4), (column5), (column6)) AS [Values](MinValue)) 
    AS MinValue 
FROM #test 
相關問題