sqlserver merge into用法
时间: 2023-12-20 15:07:17 浏览: 127
MERGE INTO语句用于将数据从一个表合并到另一个表。
语法:
```
MERGE INTO target_table [AS target_alias]
USING source_table [AS source_alias]
ON join_condition
WHEN MATCHED [AND condition] THEN
UPDATE SET column1 = value1 [, column2 = value2 ...]
WHEN NOT MATCHED [BY TARGET] THEN
INSERT (column1 [, column2 ...]) VALUES (value1 [, value2 ...])
WHEN NOT MATCHED BY SOURCE THEN
DELETE;
```
解释:
- target_table:目标表,即要合并到的表。
- target_alias:目标表的别名。
- source_table:源表,即要合并的表。
- source_alias:源表的别名。
- join_condition:连接条件,用于将目标表和源表连接起来。
- WHEN MATCHED:当目标表和源表中存在匹配的行时执行的操作。
- condition:匹配条件,用于进一步筛选匹配的行。
- UPDATE SET:要更新的列和对应的值。
- WHEN NOT MATCHED:当目标表和源表中不存在匹配的行时执行的操作。
- BY TARGET:指定只在目标表中不存在的行进行插入操作。
- INSERT:要插入的列和对应的值。
- WHEN NOT MATCHED BY SOURCE:如果源表中没有匹配的行,即目标表中的行没有对应的源表行,则执行的操作。
- DELETE:删除目标表中没有匹配的行。
示例:
假设有两个表:customers和orders。
customers表:
```
id name age
1 Alice 25
2 Bob 30
3 Charlie 35
```
orders表:
```
id customer_id order_date amount
1 2 2021-01-01 100
2 3 2021-01-02 200
3 1 2021-01-03 150
4 2 2021-01-04 120
```
合并orders表到customers表中,以customer_id作为连接条件,如果orders表中的行在customers表中不存在,则插入一条新行,否则更新customers表中的对应行的age列为源表orders表中的amount列的平均值。
```
MERGE INTO customers c
USING orders o
ON c.id = o.customer_id
WHEN MATCHED THEN
UPDATE SET c.age = (c.age + o.amount) / 2
WHEN NOT MATCHED BY TARGET THEN
INSERT (id, name, age)
VALUES (o.customer_id, '', o.amount)
WHEN NOT MATCHED BY SOURCE THEN
DELETE;
```
执行完毕后,customers表的内容如下:
```
id name age
1 Alice 75
2 Bob 110
3 Charlie 235
4 100
```
阅读全文