GaussDB数据库编程规范-关键词UPDATE&DELETE


风晓
风晓 2024-01-14 10:34:23 51750 赞同 0 反对 0
分类: 资源 标签: 国产数据库
GaussDB数据库编程规范-关键词UPDATE&DELETE

UPDATE

1.不支持UPDATE语句中直接使用LIMIT,应使用WHERE条件明确需要更新的目标行。

2.在GTM-FREE模式下,不允许跨节点事务,因此更新HASH分布中数据表时WHERE条件中必须指定分布列等值过滤条件。

3.不支持多表更新。

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

4.UPDATE语句中必须有WHERE子句,避免全表扫描。

5.不允许在UPDATE子句同时更新多个列时,被更新列同样是更新源。

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

示例:

  •  

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

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

6.UPDATE语句中禁止使用ORDER BY、GROUP BY子句,避免不必要的排序。

7.有主键/索引的表,更新时WHERE条件应结合主键/索引。

DELETE

1.不支持DELETE语句中使用LIMIT。应使用WHERE条件明确需要更新的目标行。

2.在GMT-FREE模式下,不允许跨节点事务,因此删除HASH分布表中数据时,必须在WHERE条件中指定分布列等值过滤条件。

3.不支持多表删除。

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

4.DELETE语句中必须有WHERE子句,避免全表扫描。

5.DELETE语句中禁止不应使用ORDER BY、GROUP BY子句,避免不必要的排序。

6.如果需要清空一张表,建议使用TRUNCATE,而不是DELETE。

TRUNCATE会创建新的物理文件,并在事务结束时将原文件物理删除,清空磁盘空间。而DELETE会将表中数据进行标记,直到VACCUUM FULL阶段才会真正清理磁盘空间。

7.DELETE有主键或索引的表,WHERE条件应结合主键或索引,提高执行效率。

如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!

评价 0 条
风晓L1
粉丝 1 资源 2038 + 关注 私信
最近热门资源
桌面通用(全架构)【在双系统环境下隐藏Windows启动菜单】操作指南  2057
银河麒麟桌面操作系统V10(SP1)2203-如何进行远程桌面互访?  1994
银河麒麟桌面操作系统【保留数据盘重装系统】  1804
麒麟系统各种原因开不了机解决(合集)  1587
桌面通用(全架构)【rpm包转成deb包】操作方法  931
银河麒麟桌面操作系统 V10-SP1 双系统安装 efi 分区问题  915
统信系统安装(合集)  853
统信桌面专业版【手动分区安装UOS系统】介绍  845
统启动异常几种类型(initramfs 模式)  688
最近下载排行榜
桌面通用(全架构)【在双系统环境下隐藏Windows启动菜单】操作指南 0
银河麒麟桌面操作系统V10(SP1)2203-如何进行远程桌面互访? 0
银河麒麟桌面操作系统【保留数据盘重装系统】 0
麒麟系统各种原因开不了机解决(合集) 0
桌面通用(全架构)【rpm包转成deb包】操作方法 0
银河麒麟桌面操作系统 V10-SP1 双系统安装 efi 分区问题 0
统信系统安装(合集) 0
统信桌面专业版【手动分区安装UOS系统】介绍 0
统启动异常几种类型(initramfs 模式) 0
作者收入月榜
1

prtyaa 收益393.72元

2

zlj141319 收益220.97元

3

1843880570 收益214.2元

4

IT-feng 收益213.03元

5

风晓 收益208.24元

6

777 收益172.82元

7

Fhawking 收益106.6元

8

信创来了 收益105.89元

9

克里斯蒂亚诺诺 收益91.08元

10

技术-小陈 收益79.5元

请使用微信扫码

加入交流群

请使用微信扫一扫!