最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

SQLServer之merge函数用法_MySQL

来源:动视网 责编:小采 时间:2020-11-09 20:10:31
文档

SQLServer之merge函数用法_MySQL

SQLServer之merge函数用法_MySQL:MERGE 目标表 USING 源表 ON 匹配条件 WHEN MATCHED THEN语句 WHEN NOT MATCHED THEN语句;其中最后语句分号不可以省略,且源表既可以是一个表也可以是一个子查询语句WHEN NOT MATCHED BY TARGET表示目标表不匹配,BY TARGET是默认的,所
推荐度:
导读SQLServer之merge函数用法_MySQL:MERGE 目标表 USING 源表 ON 匹配条件 WHEN MATCHED THEN语句 WHEN NOT MATCHED THEN语句;其中最后语句分号不可以省略,且源表既可以是一个表也可以是一个子查询语句WHEN NOT MATCHED BY TARGET表示目标表不匹配,BY TARGET是默认的,所


MERGE 目标表

USING 源表

ON 匹配条件

WHEN MATCHED THEN

语句

WHEN NOT MATCHED THEN

语句;

其中最后语句分号不可以省略,且源表既可以是一个表也可以是一个子查询语句

WHEN NOT MATCHED BY TARGET

表示目标表不匹配,BY TARGET是默认的,所以上面我们直接使用WHEN NOT MATCHED THEN

WHEN NOT MATCHED BY SOURCE

表示源表不匹配,即目标表中存在,源表中不存在的情况。

主要用法:

merge无法多次更新同一行,也无法更新和删除同一行

当源表和目标表不匹配时:

若数据是源表有目标表没有,则进行插入操作

若数据是源表没有而目标表有,则进行更新或者删除数据操作

当源表和目标表匹配时:

进行更新操作或者删除操作

when matched 这个子句可以有两个,当有两个时,第一个子句必须是when matched and condition且两个matched子句只会执行一个,且两个子句必须

是一个update和一个delete操作

when not matched by source和上面类似

merge icr_codemap_bak as a
using icr_codemap as b
on a.COLNAME = b.COLNAME and a.ctcode = b.ctcode
when matched and b.pbcode <> a.pbcode
then update set a.pbcode = b.pbcode
when not matched
then insert values(b.colname,b.ctcode,b.pbcode,b.note)
;

可以比对字段不一致进行更新

https://technet.microsoft.com/zh-cn/library/bb510625.aspx 这个是MSDN的网址

在 Merge Matched 操作中,只能允许执行 UPDATE 或者 DELETE 语句。

在 Merge Not Matched 操作中,只允许执行 INSERT 语句。

一个 Merge 语句中出现的 Matched 操作,只能出现一次 UPDATE 或者 DELETE 语句,否则就会出现下面的错误 - An action of type 'WHEN MATCHED' cannot appear more than once in a 'UPDATE' clause of a MERGE statement.

Merge 语句最后必须包含分号,以 ; 结束。

文档

SQLServer之merge函数用法_MySQL

SQLServer之merge函数用法_MySQL:MERGE 目标表 USING 源表 ON 匹配条件 WHEN MATCHED THEN语句 WHEN NOT MATCHED THEN语句;其中最后语句分号不可以省略,且源表既可以是一个表也可以是一个子查询语句WHEN NOT MATCHED BY TARGET表示目标表不匹配,BY TARGET是默认的,所
推荐度:
标签: sql sq 函数
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top