怎样核对两个表中的数据,在线等!!!

victory610 2009-02-26 08:21:46
我有两个表:
登记表:证券代码、股东代码、总拥有股数
股份表:证券代码、股东号、今持仓量

登记表所拥有的记录要大于股份表的记录,这三个字段是一一对应的,只是在各自的表里叫法不一样而已。

现在我需要通过写查询语句得到以下结果:

通过登记表的【证券代码】和【股东代码】来分别匹配股份表的【证券代码】和【股东号】,来查询登记表的【总拥有股数】和股份表的【今持仓量】是否相等,如果不等,就显示登记表中不等的记录来,包括登记表中有的记录而股份表中没有的记录。

不知我有没有说清楚,敬请各位高手帮忙!!!

...全文
653 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
guxiaoshi 2009-02-26
  • 打赏
  • 举报
回复

--登记表-----------------------------------------
create table land
(
financialcode nchar(10),
dormantcode nchar(10),
sumcrotch int
)
-- 股份表--------------------------------------------------
create table stock
(
financialnumber nchar(10),
dormantnumber nchar(10),
sumget int
)
--测试数据----------------------------------------------------
insert into land
select '001','01',100 union all
select '002','02',100 union all
select '003','03',100 union all
select '004','04',100 union all
select '005','05',100 union all
select '006','06',100

insert into stock
select '001','01',100 union all
select '002','02',100 union all
select '003','03',100 union all
select '004','04',200
-----------------------------------------------------
select A.*,B.* from land A,stock B
where A.financialcode=B.financialnumber and
A.dormantcode=B.dormantnumber and
A.sumcrotch<>B.sumget
union
select *,'なし' financialnumber, 'なし'dormantnumber,0 sumget from land A
where not exists
(
select 1 from stock B where A.financialcode=B.financialnumber
)
-------------------------------------------------
/*
financialcode dormantcode sumcrotch financialnumber dormantnumber sumget
---------------------------------------------------------------------------
004 04 100 004 04 200
005 05 100 なし なし 0
006 06 100 なし なし 0
*/
victory610 2009-02-26
  • 打赏
  • 举报
回复
谢谢了,我结贴了,还是dawugui厉害。
dawugui 2009-02-26
  • 打赏
  • 举报
回复
--漏了包括登记表中有的记录而股份表中没有的记录。

select m.* 
from 登记表 m , 股份表 n
where m.证券代码 = n.证券代码 and m.股东代码 = n.股东号 and m.总拥有股数 <> n.今持仓量

union all
select m.* from 登记表 m where not exists(select 1 from 股份表 n where m.证券代码 = n.证券代码 and m.股东代码 = n.股东号)[/code]
dawugui 2009-02-26
  • 打赏
  • 举报
回复
[Quote=引用楼主 victory610 的帖子:]
我有两个表:
登记表:证券代码、股东代码、总拥有股数
股份表:证券代码、股东号、今持仓量

登记表所拥有的记录要大于股份表的记录,这三个字段是一一对应的,只是在各自的表里叫法不一样而已。

现在我需要通过写查询语句得到以下结果:

通过登记表的【证券代码】和【股东代码】来分别匹配股份表的【证券代码】和【股东号】,来查询登记表的【总拥有股数】和股份表的【今持仓量】是否相等,如果不等,就显示登记表中不等的记录来,包括登记表中有的记录而股份表中没有的记录。

不知我有没有说清楚,敬请各位高手帮忙!!!
[/Quote]
select m.* , n.* 
from 登记表 m left join 股份表 n
on m.证券代码 = n.证券代码 and m.股东代码 = n.股东号 and m.总拥有股数 <> n.今持仓量
htl258_Tony 2009-02-26
  • 打赏
  • 举报
回复

-->如果不等,就显示登记表中不等的记录来
select a.证券代码,a.股东代码,a.总拥有股数,b.今持仓量
from
(select 证券代码,股东代码,sum(总拥有股数) 总拥有股数 from 登记表 group by 证券代码,股东代码) a
left join
(select 证券代码,股东号,sum(今持仓量) 今持仓量 from 股份表 group by 证券代码,股东号) b
on a.证券代码=b.证券代码 and a.股东代码=b.股东代码
where a.总拥有股数<>b.今持仓量
htl258_Tony 2009-02-26
  • 打赏
  • 举报
回复

select a.证券代码,a.股东代码,是否相等 = case when isnull(a.总拥有股数,0)=isnull(b.今持仓量,0) then '相等' else '不等' end
from
(select 证券代码,股东代码,sum(总拥有股数) 总拥有股数 from 登记表 group by 证券代码,股东代码) a
left join
(select 证券代码,股东号,sum(今持仓量) 今持仓量 from 登记表 group by 证券代码,股东号) b
on a.证券代码=b.证券代码 and a.股东代码=b.股东代码
oopp1234567890 2009-02-26
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 Happy_Stone 的回复:]
麻烦给点测试数据~~谢谢~~
[/Quote].
rhq12345 2009-02-26
  • 打赏
  • 举报
回复

select 登记表.* from 登记表,股份表 where 股份表.证券代码=登记表.证券代码
and 股份表.股东号=登记表.股东代码 and 股份表.今持仓量 <>登记表.总拥有股数
union
select * from 登记表 where 证券代码+股东代码 not in
(select 证券代码+股东代码 from 股份表)
chenyingshu 2009-02-26
  • 打赏
  • 举报
回复
给点数据啊,楼主,这样方便解答。
快乐_石头 2009-02-26
  • 打赏
  • 举报
回复
麻烦给点测试数据~~谢谢~~

34,594

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧