繁体   English   中英

如何在使用UPDATE CASE时摆脱错误“ Missing Expression”

[英]How to get rid of Error “Missing Expression” while using the UPDATE CASE

我想批量更新Paytotaxid 。我正在使用Case Statement ..如下所示

UPDATE Persons 
   SET Paytotaxid = CASE Paytotaxid 
                      WHEN = ''
                      THEN ''
                      ELSE 'XXXX' || RIGHT(TaxID,4)
                    END;

但是我不断收到错误Missing Expression

当前状态

PERSONID LASTNAME FIRSTNAME ADDRESS  CITY PAYTOTAXID TAXID

11 Tom B. Erichsen Skagen 21 Stavanger Norway 123-57-2988 123-57-2988 

22 Joe B. Erichsen Skagen 21 Stavanger minneapolis 123-57-3338 123-57-3338 

33 Mary B. Erichsen Skagen 21 Stavanger Norway 123-57-4444 123-57-4444 

44 Jaya B. Erichsen Skagen 21 Stavanger Norway 

预期结果

PERSONID LASTNAME FIRSTNAME ADDRESS CITY PAYTOTAXID TAXID

11 Tom B. Erichsen Skagen 21 Stavanger Norway XXXXX2988 123-57-2988 

22 Joe B. Erichsen Skagen 21 Stavanger minneapolis XXXXX3338 123-57-3338 

33 Mary B. Erichsen Skagen 21 Stavanger Norway XXXXX4444 123-57-4444 

44 Jaya B. Erichsen Skagen 21 Stavanger Norway 

除了错误位置的=符号之外,您还尝试使用空字符串进行相等性检查,这在Oracle中不起作用,因为空字符串被解释为NULL ,并且需要使用IS NULLIS NOT NULL

但是在这种情况下,您似乎只想更新不为null的字段。 在这种情况下,您根本不需要case 您只需要使用普通的where子句过滤掉不想更新的行。

update persons
   set Paytotaxid = 'XXXX' || SUBSTR(TaxID,-4)
 where Paytotaxid is not null

编辑 :根据注释,替换为RIGHT函数,在Oracle中无效。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM