当前位置: 代码迷 >> Oracle管理 >> 這個語句爲什麽報錯 麻煩各位~解决办法
  详细解决方案

這個語句爲什麽報錯 麻煩各位~解决办法

热度:226   发布时间:2016-04-24 06:04:20.0
這個語句爲什麽報錯 麻煩各位~
我通過SQL修改存儲過程,原SQL是這樣寫的
UPDATE   ATYW01   SET   EW=NULLIF((ISNULL(CD,0)/HCD*100),0)   FROM   ATYW01   WHERE   HCD <> 0   AND   HCD   IS   NOT   NULL;

爲什麽我改成
UPDATE   ATYW01   SET   EW=NULLIF((NVL(CD,0)/HCD*100),0)   FROM   ATYW01   WHERE   HCD <> 0   AND   HCD   IS   NOT   NULL;   它就報錯~   是在FROM那裏報錯,説是指令未正常結束~   我是不是得加個SELECT啊~   請教~

------解决方案--------------------
這是MSSQl中的寫法
Oracle:
update ATYW01 set EW=nvl(CD,0)/HCD*100
where HCD <> 0 and HCD is not NULL
------解决方案--------------------
ATYW01
就是表啊!
update 数据表
set 字段名1=赋值1,字段名2=赋值2..... where 条件
  相关解决方案