定位点类型和递归部分的类型不匹配,如何解决?
2010-01-19 16:07
309 查看
在对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
...
...
...
...
服务器: 消息 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
...
...
...
...
相关文章推荐
- SQL笔记 - 解决CTE定位点类型和递归部分的类型不匹配
- oracle账户频繁被锁,如何定位解决处理问题
- grep如何递归目录并在指定类型文件中查找
- APK IPA --------------- iis7如何添加mime类型支持所有后缀名文件下载的方法(解决特殊后缀文件无法下载的问题)
- 如何解决List<T> 类型的数据属性值去重的问题
- 如何解决斐波那契数列递归方法的性能问题
- 如何完美的解决时间轴开发中的"绝对定位"导致的Android兼容性问题(断线,断点问题)
- IE浏览器“SEC7113: CSS 因 Mime 类型不匹配而被忽略”问题的解决方法
- 如何获取gps卫星导航定位,解决getLastKnownLocation返回null
- java中是如何解决编码问题的,比如char类型的对象是如何存储的呢?
- 冲突部分Beyond Compare如何解决
- 如何解决java.lang.NoClassDefFoundError--第二部分
- 关于jquery html()方法获取带有OBJECT标签的元素内容时,出现“类型不匹配。”的解决办法
- 解决文件上传出现的参数类型不匹配的方案
- H5页面,部分 Android手机点击number电话号码/成串数字时候,会跳转到其他页面造成404错误,如何解决?
- 如何定位和解决Andorid的内存溢出问题(大总结)
- Win7下如何用Eclipse导出jar类型的文件,并且可以用鼠标双击打开jar类型的文件的方法(解决双击后一闪而过)
- ScroolView嵌套ListView以后界面默认定位到ListView部分解决办法
- 如何解决EnterLib异常处理框架最大的局限——基于异常"类型"的异常处理策略
- 网络故障分析案例:如何定位和解决网络丢包问题