sql server merge 的用法

CREATE TABLE tTable
    (
      id INT ,
      f1 VARCHAR(10) ,
      f2 VARCHAR(10) ,
      f3 VARCHAR(10)
    )
GO
INSERT  INTO tTable
   SELECT  11 ,12 , 13 , 14
INSERT  INTO tTable
   SELECT  13 ,24 ,25,26

GO

CREATE TABLE tTable2
    (
      id INT ,
      f5 VARCHAR(10) ,
      f6 VARCHAR(10)
    )
GO

CREATE PROC MERGETest
AS
    BEGIN
        MERGE INTO tTable2 T1
        USING( SELECT    id ,f3 ,f2  FROM  tTable  )T2  ON ( T1.id = T2.id )
        WHEN MATCHED
			THEN  UPDATE SET T1.f5 = T2.f2 ,T1.f6 = T2.f3
        WHEN NOT MATCHED THEN
            INSERT ( id, f5, f6 )
            VALUES ( t2.id, t2.f2, t2.f3 );

    END
GO

  

时间: 2024-07-28 21:52:08

sql server merge 的用法的相关文章

行转列:SQL SERVER PIVOT与用法解释

转自:http://www.cnblogs.com/lwhkdash/archive/2012/06/26/2562979.html 在数据库操作中,有些时候我们遇到需要实现“行转列”的需求,例如一下的表为某店铺的一周收入情况表: WEEK_INCOME(WEEK VARCHAR(10),INCOME DECIMAL) 我们先插入一些模拟数据: INSERT INTO WEEK_INCOME SELECT '星期一',1000 UNION ALL SELECT '星期二',2000 UNION

SQL Server MERGE

Merge关键字是一个神奇的DML关键字.它在SQL Server 2008被引入,它能将Insert,Update,Delete简单的并为一句.MSDN对于Merge的解释非常的短小精悍:"根据与源表联接的结果,对目标表执行插入.更新或删除操作.例如,根据在另一个表中找到的差异在一个表中插入.更新或删除行,可以对两个表进行同步.",通过这个描述,我们可以看出Merge是关于对于两个表之间的数据进行操作的. 可以想象出,需要使用Merge的场景比如: 数据同步 数据转换 基于源表对目标

SQL Server Merge语句的使用

Merge关键字在SQL Server 2008被引入,它能将Insert,Update,Delete简单的并为一句.MSDN对于Merge的解释非常的短小精悍:”根据与源表联接的结果,对目标表执行插入.更新或删除操作.例如,根据在另一个表中找到的差异在一个表中插入.更新或删除行,可以对两个表进行同步.”,通过这个描述,我们可以看出Merge是关于对于两个表之间的数据进行操作的. 可以想象出,需要使用Merge的场景比如: 数据同步 数据转换 基于源表对目标表做Insert,Update,Del

SQL SERVER BCP的用法

转自:https://www.cnblogs.com/fishparadise/p/4809014.html 前言 SQL SERVER提供多种不同的数据导出导入的工具,也可以编写SQL脚本,使用存储过程,生成所需的数据文件,甚至可以生成包含SQL语句和数据的脚本文件.各有优缺点,以适用不同的需求.下面介绍大容量数据导出导入的利器——BCP实用工具.同时在后面也介绍BULK INSERT导入大容量数据,以及BCP结合BULK INSERT做数据接口的实践(在SQL2008R2上实践). --打开

软件开发中 SQL SERVER 任务的用法

在软件开发中,经常性会用到定时任务.这个时候你可能会想到线程.但是事实中,线程方法比较麻烦.容易出错,资源竞争等问题,设计起来让你很头痛. 现在给大家提供一个新的思路,用SQL SERVER 的任务管理器来解决问题. 解决下列问题: 1.商品有购买时间限制.比如定时上线,下线.竞拍结束自动通知用户. 2.数据库中某个数据发生了变化,需要执行一段代码块(这里面的代码并不是存储过程代码,意指c#,JAVA等代码). 3.某个数据发生了变化,需要执行某个动作.(不是立马执行) 针对上面的问题,我们总结

SQL Server merge用法

有两个表名:source 表和 target 表,并且要根据 source 表中匹配的值更新 target 表. 有三种情况: source 表有一些 target 表不存在的行.在这种情况下,需要将 source 表中的行插入到 target 中. target 表有一些 source表不存在的行.这种情况下,需要从 target 表中删除行. source 表的某些行具有与 target 表中的行相同的键.但是,这些行在非键列中具有不同的值.这种情况下,需要使用来自 source 表中的值更

Sql server中DateDiff用法【转】

记录下来.每次使用都忘记.... DATEDIFF 函数 [日期和时间] 功能 返回两个日期之间的间隔. 语法 DATEDIFF ( date-part, date-expression-1, date-expression-2 ) date-part :year | quarter | month | week | day | hour | minute | second | millisecond 参数 date-part    指定要测量其间隔的日期部分. 有关日期部分的详细信息,请参见日

Sql Server事务简单用法

1 var conStr = "server=localhost;database=Data;user=sa;pwd=123456"; 2 using (var connection = new SqlConnection(conStr)) 3 { 4 connection.Open(); 5 var sql = 6 string.Format( 7 "update dbo.AutoStationData set Temperture={0} where StationNum

sql server之exists用法