使用 MERGE 在单个语句中对表执行 INSERT 和 UPDATE 操作
发布时间:2020-05-27 20:20:59 所属栏目:MySql 来源:互联网
导读:使用 MERGE 在单个语句中对表执行 INSERT 和 UPDATE 操作
|
下面是脚本之家 jb51.cc 通过网络收集整理的代码片段。 脚本之家小编现在分享给大家,也给大家做个参考。 USE AdventureWorks2012;
GO
CREATE PROCEDURE dbo.InsertUnitMeasure
@UnitMeasureCode nchar(3),@Name nvarchar(25)
AS
BEGIN
SET NOCOUNT ON;
-- Update the row if it exists.
UPDATE Production.UnitMeasure
SET Name = @Name
WHERE UnitMeasureCode = @UnitMeasureCode
-- Insert the row if the UPDATE statement failed.
IF (@@ROWCOUNT = 0 )
BEGIN
INSERT INTO Production.UnitMeasure (UnitMeasureCode,Name)
VALUES (@UnitMeasureCode,@Name)
END
END;
GO
-- Test the procedure and return the results.
EXEC InsertUnitMeasure @UnitMeasureCode = 'ABC',@Name = 'Test Value';
SELECT UnitMeasureCode,Name FROM Production.UnitMeasure
WHERE UnitMeasureCode = 'ABC';
GO
-- Rewrite the procedure to perform the same operations using the MERGE statement.
-- Create a temporary table to hold the updated or inserted values from the OUTPUT clause.
CREATE TABLE #MyTempTable
(ExistingCode nchar(3),ExistingName nvarchar(50),ExistingDate datetime,ActionTaken nvarchar(10),NewCode nchar(3),NewName nvarchar(50),NewDate datetime
);
GO
ALTER PROCEDURE dbo.InsertUnitMeasure
@UnitMeasureCode nchar(3),@Name nvarchar(25)
AS
BEGIN
SET NOCOUNT ON;
MERGE Production.UnitMeasure AS target
USING (SELECT @UnitMeasureCode,@Name) AS source (UnitMeasureCode,Name)
ON (target.UnitMeasureCode = source.UnitMeasureCode)
WHEN MATCHED THEN
UPDATE SET Name = source.Name
WHEN NOT MATCHED THEN
INSERT (UnitMeasureCode,Name)
VALUES (source.UnitMeasureCode,source.Name)
OUTPUT deleted.*,$action,inserted.* INTO #MyTempTable;
END;
GO
-- Test the procedure and return the results.
EXEC InsertUnitMeasure @UnitMeasureCode = 'ABC',@Name = 'New Test Value';
EXEC InsertUnitMeasure @UnitMeasureCode = 'XYZ',@Name = 'Test Value';
EXEC InsertUnitMeasure @UnitMeasureCode = 'ABC',@Name = 'Another Test Value';
SELECT * FROM #MyTempTable;
-- Cleanup
DELETE FROM Production.UnitMeasure WHERE UnitMeasureCode IN ('ABC','XYZ');
DROP TABLE #MyTempTable;
GO
以上是脚本之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。 如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- mysql – 在Sequel中编写一个复杂的case语句?
- Mysql应用MySQL对limit查询语句的优化方法
- Mysql必读MYSQL无法连接 提示10055错误的解决方法
- php – 是否可以使用Joomla在一个中运行多个更新查询?
- flask-sqlalchemy 一对一,一对多,多对多操作
- MySQL从PHP PDO中的存储过程检索变量
- Want to archive tables? Use Percona Toolkit’s pt-archi
- php – PDO/MySQL rowCount没有按预期返回
- 替换SQL Server数据库中所有表的所有字段的某些内容--方法一
- mysql – .SQL和.DUMP文件之间的区别
