云数据库 GAUSSDB-使用合并方式更新和插入数据:操作步骤
操作步骤
- 创建源表products,并插入数据。
1 2 3 4 5 6 7 8 9 10 11
postgres=# CREATE TABLE products ( product_id INTEGER, product_name VARCHAR2(60), category VARCHAR2(60) ); postgres=# INSERT INTO products VALUES (1502, 'olympus camera', 'electrncs'), (1601, 'lamaze', 'toys'), (1666, 'harry potter', 'toys'), (1700, 'wait interface', 'books');
- 创建目标表newproducts,并插入数据。
1 2 3 4 5 6 7 8 9 10 11 12
postgres=# CREATE TABLE newproducts ( product_id INTEGER, product_name VARCHAR2(60), category VARCHAR2(60) ); postgres=# INSERT INTO newproducts VALUES (1501, 'vivitar 35mm', 'electrncs'), (1502, 'olympus ', 'electrncs'), (1600, 'play gym', 'toys'), (1601, 'lamaze', 'toys'), (1666, 'harry potter', 'dvd');
- 使用MERGE INTO 语句将源表products的数据合并至目标表newproducts。
1 2 3 4 5 6 7
postgres=# MERGE INTO newproducts np USING products p ON (np.product_id = p.product_id ) WHEN MATCHED THEN UPDATE SET np.product_name = p.product_name, np.category = p.category WHEN NOT MATCHED THEN INSERT VALUES (p.product_id, p.product_name, p.category) ;
上述语句中使用的参数说明,请见表1。更多信息,请参见MERGE INTO。
表1 MERGE INTO语句参数说明 参数
说明
举例
INTO 子句
指定需要更新或插入数据的目标表。
- 目标表支持指定别名。
- 目标表支持复制表,但复制表不能带有含volatile函数的列(如自增列);如果enable_stream_operator=off,目标复制表需要带有主键或某一列满足unique not null约束。
取值:newproducts np
说明:名为newproducts,别名为np的目标表。
USING子句
指定源表。源表支持指定别名。
目标表是复制表时,源表也需要是复制表。
取值:products p
名为products,别名为p的源表。
ON子句
指定目标表和源表的关联条件。
关联条件中的字段不支持更新。
取值:np.product_id = p.product_id
说明:指定的关联条件为,目标表newproducts的product_id字段和源表products的product_id字段相等。
WHEN MATCHED子句
当源表和目标表中数据针对关联条件可以匹配上时,选择WHEN MATCHED子句进行UPDATE操作。
- 仅支持指定一个WHEN MATCHED子句。
- WHEN MATCHED子句可缺省,缺省时,对于满足ON子句条件的行,不进行任何操作。
- 若目标表中存在分布列,则该列不支持更新。
取值:WHEN MATCHED THEN UPDATE SET np.product_name = p.product_name, np.category = p.category
说明:当满足ON子句条件时,将目标表newproducts的product_name、category字段的值替换为源表products相对应字段的值。
WHEN NOT MATCHED子句
当源表和目标表中数据针对关联条件无法匹配时,选择WHEN NOT MATCHED子句进行INSERT操作。
取值:WHEN NOT MATCHED THEN
INSERT VALUES (p.product_id, p.product_name, p.category)
说明:将源表products中,不满足ON子句条件的行插入目标表products。
- 查询合并后的目标表newproducts。
1
postgres=# SELECT * FROM newproducts;
返回信息如下:
product_id | product_name | category ------------+----------------+----------- 1501 | vivitar 35mm | electrncs 1502 | olympus camera | electrncs 1666 | harry potter | toys 1600 | play gym | toys 1601 | lamaze | toys 1700 | wait interface | books (6 rows)