【发布时间】:2015-04-06 14:55:32
【问题描述】:
我是存储过程的新手,并设法通过谷歌创建用于插入或更新数据库的存储过程。从 Oracle 数据库中选择记录集,并根据 em_id 使用 BizTalk 将其插入或更新到 Sql 数据库表中 尝试创建一个存储过程来根据字段插入或更新记录。
CREATE PROCEDURE [dbo].[usp_InsertorUpdateDB]
@dp_id char(32),
@dv_id char(32),
@em_number char(12),
@email varchar(50),
@emergency_relation char(32),
@option1 char(16),
@status char(20),
@em_id char(35),
@em_title varchar(64),
@date_hired datetime
AS
MERGE [dbo].[em] AS [Target]
USING (SELECT @dp_id, @dv_id , @em_number, @email, @emergency_relation, @option1, @status, @em_id, @em_title, @date_hired)
AS [Source] ([dp_id], [dv_id], [em_number], [email], [emergency_relation], [option1], [status], [em_id], [em_title], [date_hired])
ON [Target].[em_id] = [Source].[em_id]
WHEN MATCHED THEN
UPDATE SET [dp_id] = [Source].[dp_id],
[dv_id] = [Source].[dv_id],
[em_number] = [Source].[em_number],
[email] = [Source].[email],
[emergency_relation] = [Source].[emergency_relation],
[option1] = [Source].[option1],
[status] = [Source].[status],
[em_id] = [Source].[em_id],
[em_title] = [Source].[em_title],
[date_hired] = [Source].[date_hired]
WHEN NOT MATCHED THEN
INSERT ([dp_id], [dv_id], [em_number], [email], [emergency_relation], [option1], [status], [em_id], [em_title],[date_hired])
VALUES ([Source].[dp_id], [Source].[dv_id], [Source].[em_number], [Source].[email], [Source].[emergency_relation], [Source].[option1], [Source].[status], [Source].[em_id], [Source].[em_title], [Source].[date_hired]);
GO
两天前我问了一个问题,因为它显示了
关键字“WHEN”附近的语法不正确。
有评论显示代码容易死锁。由于我是存储过程的新手,所以我不知道如何创建一个存储过程以进行插入或更新而不会出现死锁。我真的被卡住了。
【问题讨论】:
-
是的,MERGE 可能容易出现死锁。您需要使用传统版本。首先你做一个更新。如果 @@ROWCOUNT = 0 你做一个插入。
-
我正在从 Oracle 数据库中选择记录并使用 BizTalk 将其插入到 Sql 数据库表中。 @@ROWCOUNT 在这里有效吗?
-
是的。 Rowcount 只返回受最后一条语句影响的行数。
-
您还应该考虑重构您的 SP 以使用表值参数,特别是因为您只想将该数据视为表格。
标签: sql-server stored-procedures biztalk