Подтвердить что ты не робот

Фильтрация DataSet

У меня есть DataSet, полный заказчиков. Мне было интересно, есть ли способ фильтровать набор данных и получать только ту информацию, которую я хочу. Например, чтобы получить CostumerName и CostumerAddress для пользователя, имеющего CostumerID = 1

Возможно ли это?

4b9b3361

Ответ 1

Вы можете использовать DataTable.Select:

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:

ds.Tables[0].DefaultView.RowFilter = strExpr;  

UPDATE Я не уверен, почему вы хотите вернуть DataSet. Но я бы пошел со следующим решением:

var dv = ds.Tables[0].DefaultView;
dv.RowFilter = strExpr;
var newDS = new DataSet();
var newDT = dv.ToTable();
newDS.Tables.Add(newDT);

Ответ 2

Нет упоминания о слиянии?

DataSet newdataset = new DataSet();

newdataset.Merge( olddataset.Tables[0].Select( filterstring, sortstring ));

Ответ 3

Выше были очень близки. Здесь мое решение:

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