关于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 展开
比如实现:
表结构如下(数据是动态的):
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 展开
4个回答
展开全部
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就是所要的查询结果。
foreach (DataRow dr in dtTrees.Rows)
{
a += dr[0].ToString() + ",";
}
a = a.Trim(',');
DataRow[] drs = dtTrees.Select("pid not in (" + a + ")"); //这里用not in
//drs就是所要的查询结果。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
把select 1 from tb b where a.id=b.pid中的id以逗号分隔,弄成一个字符串,然后dtTrees.Select(id exists(弄成的字符串))
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
dtTrees.Select( "id = pid");
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不懂你要过滤什么
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询