首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

关于sql多重罗选 续

2013-11-08 
关于sql多重筛选续select 合同金额,项目名称,已付金额,运算结果 from (select 合同金额,项目名称,已付金额

关于sql多重筛选 续

select 合同金额,项目名称,已付金额,运算结果 
from 
(
select 合同金额,项目名称,已付金额,
case when 条件1 then 运算结果1 else 0 end as flag1,  
case when 条件2 then 运算结果2 else 0 end as flag2,   
case when.... end  as flag10   -- 筛选出这些项目下所有满足付款条件的记录
from tabname where 项目id  in  
(select distinct 项目id from tabname where 已付金额 < 合同金额) 
)t      -- 筛选出已付金额小于合同金额的项目
where flag1 <> 0 or flag2 <> 0 union all

select 合同金额,项目名称,已付金额,运算结果 
from 
(
select 合同金额,项目名称,已付金额,
case when 条件1 then 运算结果1 else 0 end as flag1,  
case when 条件2 then 运算结果2 else 0 end as flag2,   
case when.... end  as flag10   
from tabname where 项目id  in  
(select distinct 项目id from tabname where 已付金额 < 合同金额) 
)t      
where flag1 = 0 or flag2 = 0


非常感谢“阳泉酒家小当家”的回复,这样就可以满足我的筛选要求,但是,如何把运算结果显示出来呢?(我的运算结果是应付款金额,有多种计算方法,即运算结果1、2……10等)[/code]
[解决办法]
引用:
select 合同金额,项目名称,已付金额,运算结果 
from 
(
select 合同金额,项目名称,已付金额,
case when 条件1 then 运算结果1 else 0 end as flag1,  
case when 条件2 then 运算结果2 else 0 end as flag2,   
case when.... end  as flag10   -- 筛选出这些项目下所有满足付款条件的记录
from tabname where 项目id  in  
(select distinct 项目id from tabname where 已付金额 < 合同金额) 
)t      -- 筛选出已付金额小于合同金额的项目
where flag1 <> 0 or flag2 <> 0 union all
 
select 合同金额,项目名称,已付金额,运算结果 
from 
(
select 合同金额,项目名称,已付金额,
case when 条件1 then 运算结果1 else 0 end as flag1,  
case when 条件2 then 运算结果2 else 0 end as flag2,   
case when.... end  as flag10   
from tabname where 项目id  in  
(select distinct 项目id from tabname where 已付金额 < 合同金额) 
)t      
where flag1 = 0 or flag2 = 0


非常感谢“阳泉酒家小当家”的回复,这样就可以满足我的筛选要求,但是,如何把运算结果显示出来呢?(我的运算结果是应付款金额,有多种计算方法,即运算结果1、2……10等)


如果是要把10个运算结果都显示出来,可以这样:



select 合同金额,项目名称,已付金额,flag1,flag2,flag3...,flag10
from 
(
select 合同金额,项目名称,已付金额,
case when 条件1 then 运算结果1 else 0 end as flag1,  
case when 条件2 then 运算结果2 else 0 end as flag2,   
case when.... end  as flag10   -- 筛选出这些项目下所有满足付款条件的记录
from tabname where 项目id  in  
(select distinct 项目id from tabname where 已付金额 < 合同金额) 
)t      -- 筛选出已付金额小于合同金额的项目
where flag1 <> 0 or flag2 <> 0 union all
  
select 合同金额,项目名称,已付金额,flag1,flag2,flag3...,flag10
from 
(
select 合同金额,项目名称,已付金额,
case when 条件1 then 运算结果1 else 0 end as flag1,  
case when 条件2 then 运算结果2 else 0 end as flag2,   
case when.... end  as flag10   
from tabname where 项目id  in  
(select distinct 项目id from tabname where 已付金额 < 合同金额) 
)t      
where flag1 = 0 or flag2 = 0

热点排行