关于c#中DataTable的Select过滤

dtTrees中的数据为selecta.*fromtba,目标实现查询语句selecta.*fromtbawhereexists(select1fromtbbwherea... dtTrees中的数据为select a.* from tb a,目标实现查询语句select a.* from tb a where exists (select 1 from tb b where a.id=b.pid),现没办法改变dtTrees数据源查询,请问如何在dtTrees.Select(exists (select 1 from tb b where a.id=b.pid))中实现如此过滤查询?
比如实现:
表结构如下(数据是动态的):
id pid name
28 27 a1
29 28 a2
30 28 a3
31 27 a4
32 31 a5
33 31 a6

要求查询结果:
id pid name
28 27 a1
31 27 a4
展开
 我来答
落月Prc
推荐于2018-05-06 · TA获得超过2789个赞
知道大有可为答主
回答量:2011
采纳率:100%
帮助的人:2420万
展开全部
string a = ""; //这里可以使用StringBuilder
foreach (DataRow dr in dtTrees.Rows)
{
a += dr[0].ToString() + ",";
}
a = a.Trim(',');
DataRow[] drs = dtTrees.Select("pid not in (" + a + ")"); //这里用not in
//drs就是所要的查询结果。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zwjfriend
2011-07-12 · 超过14用户采纳过TA的回答
知道答主
回答量:45
采纳率:0%
帮助的人:38.6万
展开全部
把select 1 from tb b where a.id=b.pid中的id以逗号分隔,弄成一个字符串,然后dtTrees.Select(id exists(弄成的字符串))
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wxbqlcz
2011-07-12 · TA获得超过120个赞
知道小有建树答主
回答量:94
采纳率:0%
帮助的人:60.5万
展开全部
dtTrees.Select( "id = pid");
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
正牌小卡
2011-07-11 · TA获得超过207个赞
知道小有建树答主
回答量:499
采纳率:66%
帮助的人:148万
展开全部
不懂你要过滤什么
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式