日期:2014-05-18  浏览次数:20663 次

数据比对求SQL语句、存储过程或编写思路


2个表多字段比对

现有2个表

表A 字段类型全为字符型
字段  
XH 学号
BM 班名
KSH 考生号
XM 姓名
XB 性别
SFZH 身份证号
CSRQ 出生日期
ZYMC 专业名称
....

表B 字段类型全为字符型
字段  
XH 学号
BM 班名
KSH 考生号
XM 姓名
XB 性别
SFZH 身份证号
CSRQ 出生日期
ZYMC 专业名称
...

因没有唯一标识,所以在比较两个表的过程中得采用多条件比对

进行多条件比对可以比对出不相符的记录
但是不能明确标出那个字段不同
所以在工作中还得手工查那个字段不同

求SQL语句能明确比较出那几个字段不同


------解决方案--------------------
SQL code
--前提:表中不能有text、ntext、image、cursor 数据类型的字段。

用CheckSum()最简单:

select * from A where checksum(*) not in (select checksum(*) from B)

------解决方案--------------------
SQL code
-->差集
select * from 表A
except
select * from 表B

--交集
select * from 表A
intersect
select * from 表B

------解决方案--------------------
SQL code
 
/******************************************************************************/
/*回复:20080519007总:00027                                                   */
/*主题:数据比对                                                                         */
/*作者:二等草                                                                           */
/******************************************************************************/

set nocount on

--数据--------------------------------------
 
create table [a] ([xh] int,[ksh] varchar(4),[xm] varchar(3))
 insert into [a] select 1,'0102','aac'
 insert into [a] select 2,'0203','bbf'
 insert into [a] select 3,'0103','dse'
 insert into [a] select 4,'0104','sds'
 
create table [b] ([xh] int,[ksh] varchar(4),[xm] varchar(3))
 insert into [b] select 1,'0102','aac'
 insert into [b] select 2,'0204','bbf'
 insert into [b] select 3,'0105','dsd'
 insert into [b] select 5,'0106','rtr'
go

--代码--------------------------------------
select *,diff='a-xh,ksh,xm' from a t where not exists(select 1 from b where xh=t.xh or ksh = t.ksh or xm = t.xm)
union 
select t.*,'b-xh,ksh,xm' from b t where not exists(select 1 from a where xh=t.xh or ksh = t.ksh or xm = t.xm)
union 
select t.*,'ksh,xm' from a t,b where t.xh=b.xh and t.xm<>b.xm and t.ksh <> b.ksh
union
select t.*,'xh,xm' from a t,b where t.ksh=b.ksh and t.xm<>b.xm and t.xh <> b.xh
union
select t.*,'xh,ksh' from a t,b where t.xm=b.xm and t.xh<>b.xh and t.ksh <> b.ksh
union
select t.*,'xh' from a t,b where t.ksh=b.ksh and t.xm = b.xm and t.xh <> b.xh
union
select t.*,'ksh' from a t,b where t.ksh<>b.ksh and t.xm = b.xm and t.xh = b.xh
union
select t.*,'xm' from a t,b where t.ksh=b.ksh and t.xm <> b.xm and t.xh = b.xh

go

/*结果--------------------------------------
xh          ksh  xm   diff        
----------- ---- ---- ----------- 
2           0203 bbf  ksh
3           0103 dse  ksh,xm
4           0104 sds  a-xh,ksh,xm
5           0106 rtr  b-xh,ksh,xm
--清除------------------------------------*/
drop table a,b