首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >插入和删除不匹配的记录

插入和删除不匹配的记录
EN

Stack Overflow用户
提问于 2011-11-01 21:22:20
回答 1查看 256关注 0票数 0

我有一个asp.net网络应用程序,用户可以在数据库中更新一个表。

在Server 2008中,我有一个表如下所示:

代码语言:javascript
复制
lom_number(fk) problem   primarykey
1            AA       1
1            AA1      2
1            AA3      3
23           B        4
22           C        5

用户有一个前端,可以根据foreignkey对这些数据进行更改。

用户可以像这样更新数据:

如果目标中的

  1. = source.foreignkey和target.model = source.model不做任何事情,则在源中不存在( target.foreignkey,模型)的情况下,删除源中不存在的行
  2. ,然后插入

到目前为止我有这样的想法:

代码语言:javascript
复制
create procedure Merge_lom_problem
as
merge [dbo].lom_problem as target
using temp.lom_problem as SOURCE
on (target.lom_number = SOURCE.lom_number)
when matched and (target.problem <> SOURCE.problem)
insert (lom_number,problem) values (SOURCE.lom_number,SOURCE.problem)
when matched and 

但我对#2和#3有困难。

你能帮我把它编码吗?

EN

回答 1

Stack Overflow用户

发布于 2012-03-19 07:13:17

第一个问题你说什么都不做对吗?

尝尝这个

代码语言:javascript
复制
create procedure Merge_lom_problem
as
merge [dbo].lom_problem as target
using temp.lom_problem as SOURCE
on (target.lom_number = SOURCE.lom_number)
--when matched and target.problem = SOURCE.problem then

when not matched by source then
DELETE

when not matched by target then
insert (lom_number,problem) values (SOURCE.lom_number,SOURCE.problem)

但我不确定它会不会起作用,因为我还没有经过测试

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7973088

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档