首页  ·  知识 ·  云计算
合并两个DataSet的一种方法
windfly.  http://windfly.blog.ccidnet.com/  综合  编辑:dezai  图片来源:网络
需求描述:欲实现打印功能,一些记录项,即使内容项没有数据,也要保留其编号,并空出这一行;数据库在采集数据时,只采集了那些内容项不为空的数据,即
 需求描述:欲实现打印功能,一些记录项,即使内容项没有数据,也要保留其编号,并空出这一行;数据库在采集数据时,只采集了那些内容项不为空的数据,即只有一个包含均不为空的表。

      直观想法:设计一个和数据库中采集到的数据的那个表结构一样的表table2,只包含全部的〈id〉值,内容项由已有的Table1来填充。

     解决方案:删除Table2中那些包含在Table1中的行集,再和Table1合并。但是因为如果实际真的删除Table2中的记录,则会在下一次打印时丢失部分的值,因为在一次打印后已经删除了一部分,故使用临时表。

     实例:假设一个班级30个学生,打印学生成绩,有些学生成绩是空,但是仍要保留其姓名的位置;而数据库中已有的表Student行集中,只有那些已经有成绩的学生的记录。现在新建立一个与Student表结构完全相同的表Student2,Student2中包含所有的学生姓名即可。

     SQL代码:
IF EXISTS (SELECT * FROM tempdb.dbo.sysobjects WHERE [name]= '##T') DROP TABLE ##T
select * into ##T from Student2
Delete from ##T where StudentID in
(
select StudentID from Student
)
select * from ##T
union
(
select * from Student
)

本文作者:windfly. 来源:http://windfly.blog.ccidnet.com/
CIO之家 www.ciozj.com 微信公众号:imciow
   
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。
延伸阅读