| 導購 | 订阅 | 在线投稿
分享
 
 
 

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

2008-07-11 05:57:46  編輯來源:互聯網  简体版  手機版  評論  字體: ||
 
  原問題是這樣的:如何用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裏面還可以實現這樣的寫法,又學到了一點知識。
 
原問題是這樣的:如何用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裏面還可以實現這樣的寫法,又學到了一點知識。
󰈣󰈤
 
 
 
>>返回首頁<<
 
 
 
 
 熱帖排行
 
王朝網路微信公眾號
微信掃碼關註本站公眾號 wangchaonetcn
 
  免責聲明:本文僅代表作者個人觀點,與王朝網絡無關。王朝網絡登載此文出於傳遞更多信息之目的,並不意味著贊同其觀點或證實其描述,其原創性以及文中陳述文字和內容未經本站證實,對本文以及其中全部或者部分內容、文字的真實性、完整性、及時性本站不作任何保證或承諾,請讀者僅作參考,並請自行核實相關內容。
 
© 2005- 王朝網路 版權所有