简介
会计系统的操作管理。系统分为画面系及bat系。画面系为PHP,bat系夜间调用数据库存储过程执行,使用tcpdf作成PDF帐票,CSV文件读入,写出,备份,使用PHPDOC生成文档。apache
Merge关键字是一个神奇的DML关键字。它在SQL Server 2008被引入,它能将Insert,Update,Delete简单的并为一句。MSDN对于Merge的解释非常的短小精悍:”根据与源表联接的结果,对目标表执行插入、更新或删除操作。例如,根据在另一个表中找到的差异在一个表中插入、更新或删除行,可以对两个表进行同步。”,通过这个描述,我们可以看出Merge是关于对于两个表之间的数据进行操作的。
可以想象出,需要使用Merge的场景比如:
- 数据同步
- 数据转换
- 基于源表对目标表做Insert,Update,Delete操作
下面我们来写一个简单的Merge语句
MERGE INTO TargetTable AS T USING SourceTable AS S ON T.id = S.id WHEN MATCHED --当上面ON后面的T.id = S.id时,目标表中匹配的数据被更新 THEN UPDATE SET T.[filed] = S.[filed] WHEN NOT MATCHED --目标表中没有的ID,在源表中有,则插入到目标表中 THEN INSERT(filed1,filed2) VALUES(S.filed1,s.filed2) WHEN NOT MATCHED BY SOURCE --目标表中有,源表中没有,则删除 THEN DELETE;
Merge关键字的一些限制
- 使用Merge关键字只能更新一个表
- 源表中不能有重复的记录
转自:http://www.cnblogs.com/CareySon/archive/2012/03/07/2383690.html