| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 6384 人关注过本帖
标题:SQL视图如何实现IF的判断功能
只看楼主 加入收藏
woboy
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2010-8-22
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:9 
SQL视图如何实现IF的判断功能
IF(MID(A2,1,3)="HH1",D2-E2,D2-F2)在EXCEL中可以实现,但不知如何在SQL视图中实现,请指教!谢谢!
IF.rar (3.73 KB)
搜索更多相关主题的帖子: 如何 EXCEL 
2011-08-08 11:55
png
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:126
专家分:880
注 册:2010-10-6
收藏
得分:20 
跟你的例子学习了EXCEL功能.  SQL中可以类似 -

select *, 'FinishDate' =
    case  
        when substring(ContractNumber, 1, 3) = 'HH1' then DeliveryDate - PadA
        else  DeliverDate - PadB
    end
from YourTable




2011-08-08 23:02
woboy
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2010-8-22
收藏
得分:0 
谢谢!互相学习了,我试试SQL的,谢谢!
2011-08-09 10:14
woboy
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2010-8-22
收藏
得分:0 
刚试过,在SQL视图里无法实现!提示查询不支持 CASE SQL构造,请问在视图中该如何实现?
2011-08-11 01:34
woboy
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2010-8-22
收藏
得分:0 
这样写的(case when substring(dbo.wu_sale_order_no_bom.[合同号/客户], 1, 3) = 'HH1' then (dbo.wu_sale_order_no_bom.交货日期 -dbo.wu_bom.父出口提前期) else  (dbo.wu_sale_order_no_bom.交货日期 -dbo.wu_bom.父内销提前期) end)

不知道怎样出错了
2011-08-11 01:51
png
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:126
专家分:880
注 册:2010-10-6
收藏
得分:0 
你不是说在VIEW中不能使用CASE吧?

试一下[合同号/客户]   改成  [合同号]  ? 还不行的话, 把你的视图和查询语句贴出来让大家看看?

2011-08-11 04:50
woboy
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2010-8-22
收藏
得分:0 
SELECT TOP 100 PERCENT dbo.MRP需求$.系统单号,
      dbo.wu_sale_order_no_bom.[合同号/客户],
      dbo.wu_sale_order_no_bom.交货日期 AS [交货(走柜)日期],
      dbo.wu_sale_order_no_bom.订单备注,
      dbo.wu_sale_order_no_bom.货号 AS 父件货号,
      dbo.wu_sale_order_no_bom.货名 AS 父件货名,
      dbo.wu_sale_order_no_bom.订单数量, dbo.wu_bom.子件货号,
      dbo.wu_bom.子件货名, dbo.MRP需求$.单位, dbo.wu_bom.规格,
      dbo.MRP需求$.净需求量, dbo.wu_bom.用量, dbo.MRP需求$.采购单价,
      dbo.MRP需求$.金额,
      dbo.wu_sale_order_no_bom.订单数量 * dbo.wu_bom.用量 AS 订单子件用量,
      dbo.wu_bom.[工艺链(+)], dbo.wu_bom.子件存货类型,
      dbo.wu_sale_order_no_bom.装箱数, dbo.wu_sale_order_no_bom.单件CBM,
      dbo.wu_bom.子件仓库, dbo.wu_bom.子件生产车间, dbo.wu_bom.子件供应商,
      dbo.wu_bom.工序单价, dbo.wu_bom.父件生产车间, dbo.wu_bom.父件工序,
      dbo.wu_sale_order_no_bom.订单状态, dbo.MRP需求$.变更日期,
      dbo.MRP需求$.变更说明, dbo.MRP需求$.建议订单顺序, dbo.wu_bom.父内销提前期,
      dbo.wu_bom.父出口提前期, dbo.wu_bom.子内销提前期,
      dbo.wu_bom.子出口提前期
(case when substring(dbo.wu_sale_order_no_bom.[合同号/客户], 1, 3) = 'HH1' then (dbo.wu_sale_order_no_bom.交货日期 -dbo.wu_bom.父出口提前期)
else  (dbo.wu_sale_order_no_bom.交货日期 -dbo.wu_bom.父内销提前期) end)

FROM dbo.MRP需求$ INNER JOIN
      dbo.wu_sale_order_no_bom ON
      dbo.MRP需求$.系统单号 = dbo.wu_sale_order_no_bom.系统订单号 INNER JOIN
      dbo.wu_bom ON dbo.wu_sale_order_no_bom.货号 = dbo.wu_bom.父件货号 AND
      dbo.MRP需求$.货品编号 = dbo.wu_bom.子件货号
ORDER BY dbo.MRP需求$.建议订单顺序, dbo.MRP需求$.系统单号,
      dbo.wu_sale_order_no_bom.[合同号/客户]

应该不会是[合同号/客户]的影响
请帮忙看看那里出来问题
2011-08-11 09:06
png
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:126
专家分:880
注 册:2010-10-6
收藏
得分:0 
dbo.wu_bom.子出口提前期
(case when substring(dbo.wu_.....

dbo.wu_bom.子出口提前期  ,
(case when substring(dbo.wu_.....
2011-08-11 22:10
woboy
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2010-8-22
收藏
得分:0 
[合同号/客户]   改成了  [合同号],按png提供的加了逗号也不行!还是提示:“查询不支持 CASE SQL构造”。哪位师傅提示提示,指教指教啊!谢谢
2011-08-11 22:50
woboy
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2010-8-22
收藏
得分:0 
问题解决了!谢谢!是SQL的版本问题,打了SP4补丁后就正常了
2011-08-12 11:01
快速回复:SQL视图如何实现IF的判断功能
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.084101 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved