华为云云数据库GaussDBUPDATE_云淘科技

不支持UPDATE语句中直接使用LIMIT,应使用WHERE条件明确需要更新的目标行。
在GTM-FREE模式下,不允许跨节点事务,因此更新HASH分布中数据表时WHERE条件中必须指定分布列等值过滤条件。
不支持多表更新。

多表更新即在单条SQL语句中,对多个表进行更新。

UPDATE语句中必须有WHERE子句,避免全表扫描。
不允许在UPDATE子句同时更新多个列时,被更新列同样是更新源。

同时更新多列,且更新源相同,在不同的数据库下行为不同,为了避免带来兼容性问题,业务层应避免上述操作。

示例:

UPDATE table SET col1 = col2, col3 = col1 WHERE col1 = 1;

该语句在GaussDB中,col3的值为原col1的值;而MySQL中,col3的值为col2的值(因为col2的值被赋予给了col1)。

UPDATE语句中禁止使用ORDER BY、GROUP BY子句,避免不必要的排序。
有主键/索引的表,更新时WHERE条件应结合主键/索引。

父主题: 数据库编程规范

同意关联代理商云淘科技,购买华为云产品更优惠(QQ 78315851)

内容没看懂? 不太想学习?想快速解决? 有偿解决: 联系专家