informix多张表UPDATE时不能用别名

informix数据库9.5版本,我使用的时候,update一张主表,通过其他表关联,将其他表的字段值赋值到该主表中。 主表USER 表字段为(ID,NAME) ,另一张附表STU,表字段为(ID,NAME2) UPDATE USER T1 SET T1.NAME = (SELECT T2.NAME2 FROM STU T2 WHERE T1.ID = T2.ID) WHERE EXISTS (SELECT 1 FROM STU T2 WHERE T1.ID =T2.ID); 这个语句会报错。

修改成如下语句,不报错了。 UPDATE USER SET USER.NAME = (SELECT T2.NAME2 FROM STU T2 WHERE USER.ID = T2.ID) WHERE EXISTS (SELECT 1 FROM STU T2 WHERE USER.ID =T2.ID);

不知道其他版本是否支持,这个版本不支持主表带有别名去更新字段,oracle都没有问题。

转载于:https://my.oschina.net/meSpace/blog/2482049

你可能感兴趣的:(informix多张表UPDATE时不能用别名)