WITH table AS及其他

WITH table AS 临时表使用方法

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
IF EXISTS (SELECT * FROM sys.views WHERE object_id = OBJECT_ID(N'[dbo].[v_Order_Production_Scheduling]'))
BEGIN
    DROP VIEW [dbo].v_Order_Production_Scheduling;
END
GO
-- =============================================

-- =============================================
CREATE view [dbo].v_Order_Production_Scheduling AS 
WITH tb AS (SELECT VBELN, POSNR, ETENR, WMENG, EDATU, VRKME, WERKS, o.new_number as o_number, od.new_number as od_number, sd.new_number as sd_shippingline, sd.new_schedulingdetailsId as sd_schedulingdetailsId
            FROM PRODUCTION_SCHEDULING as ps 
            LEFT JOIN dbo.new_order as o 
            ON ps.VBELN = o.new_sapnumber 
            LEFT JOIN dbo.new_orderdetails as od 
            ON ps.POSNR = od.new_sapnumber 
            AND o.new_orderId = od.new_orderId 
            LEFT JOIN dbo.new_schedulingdetails as sd 
            ON ps.ETENR = sd.new_number 
            AND od.new_orderdetailsId = sd.new_orderdetailsid 
            )

SELECT VBELN, POSNR, ETENR, WMENG, EDATU, VRKME, WERKS, o_number, od_number, sd_shippingline, sd_schedulingdetailsId, '更新' AS describe 
FROM tb 
WHERE tb.sd_schedulingdetailsId IS NOT NULL 
UNION ALL
SELECT VBELN, POSNR, ETENR, WMENG, EDATU, VRKME, WERKS, o_number, od_number, sd_shippingline, sd_schedulingdetailsId, '创建' AS describe 
FROM tb 
WHERE tb.o_number IS NOT NULL 
AND tb.od_number IS NOT NULL 
AND ETENR IS NOT NULL
AND tb.sd_schedulingdetailsId IS NULL

两个对象都没有判空处理
如果前一对象为NULL,结果怎么样?
如果后一对象为NULL,结果怎么样?

schedulingdetails.Attributes["new_planline"].ToString() != viewlist.Tables[0].Rows[i]["ETENR"].ToString()

试验如下

string a = null;
string b = null;
string c = "c";
string d = "d";
Console.WriteLine(a != c);
Console.WriteLine(c != a);
Console.WriteLine(a != b);
Console.WriteLine(c != d);

结果

选项集赋值

schedulingdetails.Attributes["new_factory"] = new OptionSetValue(int.Parse(viewlist.Tables[0].Rows[i]["WERKS"].ToString()));
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值