云数据库 GAUSSDB-MERGE INTO:示例

时间:2024-01-23 20:09:28

示例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
-- 创建目标表products和源表newproducts,并插入数据
postgres=# CREATE TABLE products
(
product_id INTEGER,
product_name VARCHAR2(60),
category VARCHAR2(60)
);

postgres=# INSERT INTO products VALUES (1501, 'vivitar 35mm', 'electrncs');
postgres=# INSERT INTO products VALUES (1502, 'olympus is50', 'electrncs');
postgres=# INSERT INTO products VALUES (1600, 'play gym', 'toys');
postgres=# INSERT INTO products VALUES (1601, 'lamaze', 'toys');
postgres=# INSERT INTO products VALUES (1666, 'harry potter', 'dvd');

postgres=# CREATE TABLE newproducts
(
product_id INTEGER,
product_name VARCHAR2(60),
category VARCHAR2(60)
);

postgres=# INSERT INTO newproducts VALUES (1502, 'olympus camera', 'electrncs');
postgres=# INSERT INTO newproducts VALUES (1601, 'lamaze', 'toys');
postgres=# INSERT INTO newproducts VALUES (1666, 'harry potter', 'toys');
postgres=# INSERT INTO newproducts VALUES (1700, 'wait interface', 'books');

-- 进行MERGE INTO操作
postgres=# MERGE INTO products p   
USING newproducts np   
ON (p.product_id = np.product_id)   
WHEN MATCHED THEN  
  UPDATE SET p.product_name = np.product_name, p.category = np.category WHERE p.product_name != 'play gym'  
WHEN NOT MATCHED THEN  
  INSERT VALUES (np.product_id, np.product_name, np.category) WHERE np.category = 'books';
MERGE 4

-- 查询更新后的结果
postgres=# SELECT * FROM products ORDER BY product_id;
 product_id |  product_name  | category  
------------+----------------+-----------
       1501 | vivitar 35mm   | electrncs
       1502 | olympus camera | electrncs
       1600 | play gym       | toys
       1601 | lamaze         | toys
       1666 | harry potter   | toys
       1700 | wait interface | books
(6 rows)

-- 删除表
postgres=# DROP TABLE products;
postgres=# DROP TABLE newproducts;
support.huaweicloud.com/devg-v1-gaussdb/gaussdb_devg_0617.html