http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 2702|回复: 5

[其他] 相同表结构的两个datatable,A表数据包含B表数据,删除A表中与B表相同的记录

[复制链接]
发表于 2013-10-24 10:22:24 | 显示全部楼层 |阅读模式
本帖最后由 lewis_fang 于 2013-10-24 10:29 编辑

如题:
相同表结构的两个datatable,A表数据包含B表数据,删除A表中与B表相同的记录
A表
姓名  学号  性别 成绩
A        01     男    90
B        02     女    88
C        03     女    59

B表
姓名  学号  性别 成绩
C        03     女    59

怎么删除A表中的学生为“C”的记录,所有字段名不能作为参考值
附:B表不一定只有1条记录



1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2013-10-24 10:25:52 | 显示全部楼层
根据学号删除就是了。
delete A  where 学号 in(select  B.学号 from B inner join a on B.学号=a.学号)
 楼主| 发表于 2013-10-24 10:30:58 | 显示全部楼层
本帖最后由 lewis_fang 于 2013-10-24 10:41 编辑
站长苏飞 发表于 2013-10-24 10:25
根据学号删除就是了。
delete A  where 学号 in(select  B.学号 from B inner join a on B.学号=a.学号)

只是DataTable,没有数据库
我下面的做法行不通,使用for循环
for (int i = 0; i < B.Rows.Count;i++ )
            {
                DataRow dr = A.NewRow();
                foreach(DataRow drow in A.Rows)
                {
                    if(drow.Equals(B.Rows))
                    {
                        dr = drow;
                        break;
                    }
                }

                A.Rows.Remove(dr);
            }
发表于 2013-10-24 11:08:14 | 显示全部楼层
  if(drow.Equals(B.Rows))应该是不会相等的,我建议你直接通过属性比较,而不是直接比较对象,你直接取其中的学号试试
 楼主| 发表于 2013-10-24 12:26:31 | 显示全部楼层
站长苏飞 发表于 2013-10-24 11:08
if(drow.Equals(B.Rows))应该是不会相等的,我建议你直接通过属性比较,而不是直接比较对象,你直接取其 ...

感谢站长的回答{:soso_e181:}
属性比较是可以,但是datatable中的栏位比较多,没有直接的key值
这个问题已经被我绕过去了,结贴了{:soso_e100:}
发表于 2013-10-24 13:03:21 | 显示全部楼层
恩好,不管什么方法只要能解决问题就行
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-5-3 21:39

© 2014-2021

快速回复 返回顶部 返回列表