当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 用一条SQL实现:一行多个字段数据的最大值

MSSQL
SQL 实用语句
SQL Server 版本变更检查 警告
创建动态MSSQL数据库表
常用SQL功能语句
table 行转列的sql详解
三步堵死 SQL Server注入漏洞
sql 去零函数 datagridview中数字类型常出现后面的零不能去掉
insert into tbl() select * from tb2中加入多个条件
Sql Server 字符串聚合函数
通过备份记录获取数据库的增长情况
sqlserver 2000 远程连接 服务器的解决方案
SQL 合并多行记录的方法总汇
批处理 动态sql
在sp_executesql中使用like字句的方法
SQL中的left join right join
Sql Server 数据库索引整理语句,自动整理数据库索引
查询数据排名情况SQL
sqlserver 比较两个表的列
mssql 两表合并sql语句
SQL SERVER 文件和文件组

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 101 ::
收藏到网摘: n/a

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