欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【用一条SQL实现:一行多个字段数据的最大值】,下面是详细的分享!
用一条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里面还可以实现这样的写法,又学到了一点知识。
以上所分享的是关于用一条SQL实现:一行多个字段数据的最大值,下面是编辑为你推荐的有价值的用户互动:
相关问题:sql中,如果有两条一样的数据,根据某个字段的最大...
答:update T2 set T2.B2=T1.B1 from (Select max(A1) as A1,C1,D1 from T1 group by C1,D1) T3 left join T1 On T3.A1=T1.A1 left join T2 on t1.D1=t2.A2 where t1.C1=2000 我的想法就是 把T1一样的合成一条 找到最大的A1 。然后用找到的A1去从新... >>详细
相关问题:sql 一个字段有多条数据 在一行显示
答:方法一:直接构造(这种方法针对这样的问题比较好,但实用性不大)DECLARE @result VARCHAR(1024)SET @result = ''select @result += b.f_measure+',' from t_quality_qi_special t , t_quality_qi_measure b where t.f_id=b.f_special_sn and t... >>详细
相关问题:sql语句 如何将一个表中的多条数据显示在一行呢???
答:用游标可以实现。 假设你这个表名字为student --定义变量@sql用来存要执行的sql语句 declare @sql varchar(5000) set @sql='select 'student_info: ', ' --定义 @column来存游标取得每一行数据 declare @column varchar(20) --定义游标 declare ... >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
