定位点类型和递归部分的类型不匹配,如何解决?

在对BOM表汇总查询的时候,做了一个小的改动,就出现了下面的我问题:

服务器: 消息 240,级别 16,状态 1,行 1
在递归查询 "Bom1" 的列 "UsedQty" 中,定位点类型和递归部分的类型不匹配。

其中Mom1是自己定义的表名。

CSDN上有说:定位点成员和递归成员的类型需要一致.. 所以这里将定位点的routes转换为varchar,而递归成员也转换为varchar。

所以,只要把计算结果进行数据类型转换就可以了。

 

开始的时候没有加Cast(),也就是黄色部分,就一直报上面的错误,这是修改后的SQL语句:

with Bom1(BomID,mInvCode1,mInvCode2,bInv,BaseQtyN,BaseQtyD, UsedQty,layer,cInvName,cInvStd,ccomunitname,InvAttr,bself,bPurchase) as
(
select bb.BomID,a.InvCode,a.InvCode,b.InvCode,bo.BaseQtyN, bo.BaseQtyD, cast(bo.BaseQtyN / bo.BaseQtyD as nvarchar(4000)) as UsedQty,1 as layer,i.cInvName,i.cInvStd,c.ccomunitname,
InvAttr = (case when i.bself = 1 then '自制'
 when i.bself =0 and i.bPurchase = 1 then '采购'
 else '无'
 end),
i.bself, i.bPurchase
from Bom_Bom as bb
...

...

...
union all
select Bom1.BomID,Bom1.mInvCode1,a.InvCode,b.InvCode,bo.BaseQtyN, bo.BaseQtyD, cast(bo.BaseQtyN / bo.BaseQtyD * Bom1.UsedQty as nvarchar(4000)) as UsedQty, layer + 1,i.cInvName,i.cInvStd,c.ccomunitname,
InvAttr = (case when i.bself = 1 then '自制'
 when i.bself =0 and i.bPurchase = 1 then '采购'
 else '无'
 end),
i.bself, i.bPurchase
from Bom_Bom as bb
...

...

...
...

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值