当前位置:首页 > 网络编程 > 数据库 > SQL Server > 用一条SQL实现:一行多个字段数据的最大值

用一条SQL实现:一行多个字段数据的最大值

点击次数:26 次 发布日期:2009-01-03 22:09:15 作者:源代码网
源代码网推荐

源代码网整理以下原问题是这样的:如何用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里面还可以实现这样的写法,又学到了一点知识。

源代码网供稿.
网友评论 (0)
会员中心
网络编程
本站推荐
网络编程之精华