首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >过滤DataSet

过滤DataSet
EN

Stack Overflow用户
提问于 2011-05-15 18:38:27
回答 3查看 105.7K关注 0票数 23

我有一个装满顾客的DataSet。我想知道是否有任何方法可以过滤数据集并只获得我想要的信息。例如,要获取具有CostumerID = 1的客户的CostumerNameCostumerAddress

有可能吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-05-15 18:43:14

您可以使用DataTable.Select

代码语言:javascript
复制
var strExpr = "CostumerID = 1 AND OrderCount > 2";
var strSort = "OrderCount DESC";

// Use the Select method to find all rows matching the filter.
foundRows = ds.Table[0].Select(strExpr, strSort);  

或者,您可以使用DataView

代码语言:javascript
复制
ds.Tables[0].DefaultView.RowFilter = strExpr;  

UPDATE我不知道为什么要返回一个DataSet。但我会采用以下解决方案:

代码语言:javascript
复制
var dv = ds.Tables[0].DefaultView;
dv.RowFilter = strExpr;
var newDS = new DataSet();
var newDT = dv.ToTable();
newDS.Tables.Add(newDT);
票数 44
EN

Stack Overflow用户

发布于 2014-07-09 04:56:21

没有提到合并?

代码语言:javascript
复制
DataSet newdataset = new DataSet();

newdataset.Merge( olddataset.Tables[0].Select( filterstring, sortstring ));
票数 6
EN

Stack Overflow用户

发布于 2014-02-21 06:14:21

以上两项都非常接近。这是我的解决方案:

代码语言:javascript
复制
Private Sub getDsClone(ByRef inClone As DataSet, ByVal matchStr As String, ByRef outClone As DataSet)
    Dim i As Integer

    outClone = inClone.Clone
    Dim dv As DataView = inClone.Tables(0).DefaultView
    dv.RowFilter = matchStr
    Dim dt As New DataTable
    dt = dv.ToTable
    For i = 0 To dv.Count - 1
        outClone.Tables(0).ImportRow(dv.Item(i).Row)
    Next
End Sub
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6007872

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档