用一條SQL實現:一行多個字段數據的最大值

原問題是這樣的:如何用SQL語句(不是Oracle),求出下表每一行的5個字段中的最大值,最後生成一個新字段。

例如:

第一行最大值 -5.0 (c字段) 空值忽略

第二行最大值 -5.5 (a字段) 空值忽略

ab c d e

-21.5-15.0-5.0

-5.5-11.5

-5.0-16.5-10.5

-9.0

-11.5-14.0-8.5

-10.5-11.0-15.5-14.0-12.5

-15.0-11.0-10.5-17.0

-12.5-8.0-14.5

-8.0-12.0

-6.5-11.5-19.5-22.5-20.0

-13.0-7.5-14.0

-8.0-12.0-12.0

。。。。。。

解決方法如下:

1create table T(A decimal(10,1), B decimal(10,1), C decimal(10,1), D decimal(10,1), E decimal(10,1))

2insert T select -21.5,-15.0,-5.0, null, null

3union all select -5.5,-11.5,null, null, null

4union all select -1.0,-16.5,-10.5, null, null

5

6

7select *,

8max_value=(

9select max(A) from

10(

11select A

12union all

13select B

14union all

15select C

16union all

17select D

18union all

19select E

20)tmp)

21from T

22

--result

A B C D E max_value

------------ ------------ ------------ ------------ ------------ ------------

-21.5 -15.0 -5.0 NULL NULL -5.0

-5.5 -11.5 NULL NULL NULL -5.5

-1.0 -16.5 -10.5 NULL NULL -1.0

(3 row(s) affected)

這一方法,自我感覺不錯,還真的第1次看到這樣的寫法。原來SQL裏面還可以實現這樣的寫法,又學到了一點知識。

 
Oracle:一條SQL實現將多行數據並爲一行顯示
家庭信息表:ID 學生姓名 成員姓名1 張三 成員12 張三 成員23 李四 成員14 李四 成員2現在要顯示爲:學生姓名 成員姓名1 成員姓名2張三 成員...查看完整版>>Oracle:一條SQL實現將多行數據並爲一行顯示
 
有關讀取SQL數據庫裏TEXT和NTEXT類型字段內容的問題
老是遇到TEXT類型和NTEXT類型的字段讀不出來的問題.今天弄了半天,又查了資料,終于把這個問題搞定了首先我們應該了解這兩個類型的字段到底有什麽不同:雖然看起這他們是叫TEXT,但他不是用來保存文本的,實際上是用來保存...查看完整版>>有關讀取SQL數據庫裏TEXT和NTEXT類型字段內容的問題
 
巧用一條SQL實現其他進制到十進制的轉換
本文主要講解了在Oralce中如何通過一條SQL實現其他進制到十進制的轉換實例代碼,大家可以把它封裝成一個通用函數來進行使用,面向其它進制時大家可以根據例子將power的底數改成相應的進制就可以了。在下面的示例當中...查看完整版>>巧用一條SQL實現其他進制到十進制的轉換
 
在SQL 2005中實現循環每一行做一定的操作
如果我們想對一個表的每一行做出比較複雜的操作,大多會想到用遊標,本文中,我們將換一種思路,用SQL Server 2005中的新函數ROW_NUMBER()和while循環來對每一行執行操作。詳細的示例代碼如下: select Department_N...查看完整版>>在SQL 2005中實現循環每一行做一定的操作
 
查詢數據庫表和字段sql語句
今天整理資料時看到有這樣一個查詢數據庫中的表和字段信息的語句,很強! 就是忘了當初誰寫的了,印像中該是鄒建所創。也貼出來以後備用吧。1SELECT 2表名 = CASE a.colorder WHEN 1 THEN c.name ELSE '' END, 3序 ...查看完整版>>查詢數據庫表和字段sql語句