描述:有三个表A01,B01,C01 现以C来比较两个表,C01表中存有A01.id,b01.id....
C01结构是这样的 ID,A01ID,B01ID,A01NAME,A01IDCARD,A01SEX,B01NAME,BO1IDCARD,BO1SEX.....就不一一列举了.
下边是我写的meger into
meger into C01 C
using A01 A on(c.A1ID=A.ID)
when matched then
update set C.A1NAME=A.NAME,C.A1SEX=A.SEX,C.A1IDCARD=A.IDCARD
when not matched then
insert (C.A1id,C.A1NAME,C.A1IDCARD,C.A1SEX)
values (A.ID,A.NAME,A.IDCARD,A.SEX);
commit;
以上相同的更新成功了,如果插入了一条叫张三的记录(ID为:6676$5675,身份证号:1234567,姓名:张三,性别:男)
问当与B01这个表在做比较的时候,B01表中也有个叫张三的身份证号为1234567,性别男这个时候怎么办:
我的理解是这个时候B01这个表中的张三应该和A01这个表中的张三合成一条记录不应该在单独插入,这种meger into 怎么写谢谢.
C01结构是这样的 ID,A01ID,B01ID,A01NAME,A01IDCARD,A01SEX,B01NAME,BO1IDCARD,BO1SEX.....就不一一列举了.
下边是我写的meger into
meger into C01 C
using A01 A on(c.A1ID=A.ID)
when matched then
update set C.A1NAME=A.NAME,C.A1SEX=A.SEX,C.A1IDCARD=A.IDCARD
when not matched then
insert (C.A1id,C.A1NAME,C.A1IDCARD,C.A1SEX)
values (A.ID,A.NAME,A.IDCARD,A.SEX);
commit;
以上相同的更新成功了,如果插入了一条叫张三的记录(ID为:6676$5675,身份证号:1234567,姓名:张三,性别:男)
问当与B01这个表在做比较的时候,B01表中也有个叫张三的身份证号为1234567,性别男这个时候怎么办:
我的理解是这个时候B01这个表中的张三应该和A01这个表中的张三合成一条记录不应该在单独插入,这种meger into 怎么写谢谢.
解决方案 »
- 怎么查看本机某个数据库的连接字符串(很菜鸟)
- 表分析这个罪魁祸首?!究竟做了什么导致执行计划的改变—十万火急续三
- 谁有kettle的中文版,可以提供一下吗
- Internet 信息服务IIS 如何安装?
- 结合两个字段写一个小于where 准备时间 < to_date('12-01', 'hh:mi')select 报错
- 各位大侠:在xp下安装oracle8.1.6如果马上使用的话可以,但是重新启动后就不行了?输入system/manager不能连接?
- 请Croatia(Croatia) 来此领取你应得的分!
- 哪个快?
- 资料已发,收到的请up
- 数据库移植问题
- SQL语句:判断给定的字符串中是否含有多个不同的字符串
- 关于一些命令,大家进来帮我解释一下....
using (select * from A01 union select * from B01) A
on(c.A1ID=A.ID)
when matched then
update set C.A1NAME=A.NAME,C.A1SEX=A.SEX,C.A1IDCARD=A.IDCARD
when not matched then
insert (C.A1id,C.A1NAME,C.A1IDCARD,C.A1SEX)
values (A.ID,A.NAME,A.IDCARD,A.SEX);
commit; 用union连接两个查询结果,它自动把相同的记录屏蔽掉;
记住,不能用union all连接
ORA-30926:unable to get a stable set of rows in the source tables
using (select * from sqfhr union select * from sqfsb) h
on (m.hr_psn_id=h.hr_id)
when matched then
update set m.hrname=h.name
when not matched then
insert (m.id,m.hr_psn_id,m.hrname)
values (h.id,h.hr_id,h.name);
commit;
这一句产生的数据集无法通过你的关联条件(m.hr_psn_id=h.hr_id) 产生唯一的记录。PS:我感觉你对MERGE的理解还是不够深入,给你个链接去看看
http://xsb.itpub.net/post/419/30766
using (select id,hr_id,name from sqfhr
union select id,hr_id,name from sqfsb a where not exists(select 1 from sqfhr b where a.name=b.name)
) h
on (m.hr_psn_id=h.hr_id)
when matched then
update set m.hrname=h.name
when not matched then
insert (m.id,m.hr_psn_id,m.hrname)
values (h.id,h.hr_id,h.name);
commit;
merge into sqfmdm m
using (select id,hr_id,name from sqfhr
union select id,hr_id,name from sqfsb a where not exists(select 1 from sqfhr b where a.name=b.name and a.hr_id=b.hr_id)
) h
on (m.hr_psn_id=h.hr_id)
when matched then
update set m.hrname=h.name
when not matched then
insert (m.id,m.hr_psn_id,m.hrname)
values (h.id,h.hr_id,h.name);
commit;