日期:2014-05-16  浏览次数:20545 次

MSSQL疑难问题,在线等大神
(如果文字看不懂可以直接看代码和错误提示信息)
表FGB_INNERBAR中 有列 fgbno,outbarcode,itmcode,field4;
现在需要更新 FGB_INNERBAR中 fgbno=fg 的列field4.
field4值为 fgb_innerbar 中 fgbno 值为
 fgb_pick_mstr 中所有itmcode 值为  fgbno=LCB1306004856  时 的取值的范围内
  fgbno、outbarcode升序排列的行数.
请问各位大神们怎么写SQL 语句.因为要求比较复杂,可能写的有点儿难懂
(语言组织确实有点混乱,但已经尽我所能了,可以参考看我写的语句来理解要求)
下面为我写的,有错误.
update  FGB_INNERBAR set field4= (select row_number()
over (order by  fgbno,outbarcode) FROM FGB_INNERBAR   
 where fgbno in (select fgbno from fgb_pick_mstr where itmcode=
             (select itmcode from fgb_pick_mstr where fgbno='LCB1306004856' )
        )     )
       WHERE fgbno ='LCB1306004856'

执行时提示一下错误  :
<<
消息 512,级别 16,状态 1,第 1 行
子查询返回的值不止一个。当子查询跟随在 =、!=、<、<=、>、>= 之后,或子查询用作表达式时,这种情况是不允许的。
语句已终止。
>>

------解决方案--------------------
引用:
Quote: 引用:

如果是只需要总的行数,可以这样:
update  FGB_INNERBAR 
set field4= 
(
select COUNT(*) 
FROM FGB_INNERBAR   
where fgbno in 
(
select fgbno from fgb_pick_mstr 
where itmcode=(select itmcode from fgb_pick_mstr where fgbno='LCB1306004856' )
)     
)
WHERE fgbno ='LCB1306004856'

不是总行数,是这行是第N行那值就为N


试试这个:
;with t
as
(
select field4,fgbno,row_number() over (order by  fgbno,outbarcode) as rownum
FROM FGB_INNERBAR   
where fgbno in 
(
select fgbno from fgb_pick_mstr 
where itmcode=(select itmcode from fgb_pick_mstr where fgbno='LCB1306004856' )
)   
)

update  t 
set field4= rownum
WHERE fgbno ='LCB1306004856'