DataView 클래스

정의

정렬, 필터링, 검색, 편집 및 탐색을 수행할 수 있는 DataTable 의 데이터 바인딩 가능한 사용자 지정된 보기를 나타냅니다. DataView 에서는 데이터를 저장하지 않지만 해당하는 DataTable의 연결된 뷰를 나타냅니다. DataView의 데이터 변경 내용은 DataTable에 영향을 줍니다. DataTable의 데이터 변경 내용은 이와 연결된 모든 DataView에 영향을 줍니다.

public ref class DataView : System::ComponentModel::MarshalByValueComponent, System::Collections::IList, System::ComponentModel::IBindingListView, System::ComponentModel::ISupportInitialize, System::ComponentModel::ISupportInitializeNotification, System::ComponentModel::ITypedList
public ref class DataView : System::ComponentModel::MarshalByValueComponent, System::Collections::IList, System::ComponentModel::IBindingList, System::ComponentModel::ISupportInitialize, System::ComponentModel::ITypedList
public ref class DataView : System::ComponentModel::MarshalByValueComponent, System::Collections::IList, System::ComponentModel::IBindingListView, System::ComponentModel::ISupportInitializeNotification, System::ComponentModel::ITypedList
public ref class DataView : System::ComponentModel::MarshalByValueComponent, System::ComponentModel::IBindingListView, System::ComponentModel::ISupportInitializeNotification, System::ComponentModel::ITypedList
public class DataView : System.ComponentModel.MarshalByValueComponent, System.Collections.IList, System.ComponentModel.IBindingListView, System.ComponentModel.ISupportInitialize, System.ComponentModel.ISupportInitializeNotification, System.ComponentModel.ITypedList
public class DataView : System.ComponentModel.MarshalByValueComponent, System.Collections.IList, System.ComponentModel.IBindingList, System.ComponentModel.ISupportInitialize, System.ComponentModel.ITypedList
public class DataView : System.ComponentModel.MarshalByValueComponent, System.Collections.IList, System.ComponentModel.IBindingListView, System.ComponentModel.ISupportInitializeNotification, System.ComponentModel.ITypedList
public class DataView : System.ComponentModel.MarshalByValueComponent, System.ComponentModel.IBindingListView, System.ComponentModel.ISupportInitializeNotification, System.ComponentModel.ITypedList
type DataView = class
    inherit MarshalByValueComponent
    interface ICollection
    interface IEnumerable
    interface IList
    interface IBindingList
    interface IBindingListView
    interface ISupportInitialize
    interface ISupportInitializeNotification
    interface ITypedList
type DataView = class
    inherit MarshalByValueComponent
    interface IBindingList
    interface IList
    interface ICollection
    interface IEnumerable
    interface ITypedList
    interface ISupportInitialize
type DataView = class
    inherit MarshalByValueComponent
    interface IBindingListView
    interface IBindingList
    interface IList
    interface ICollection
    interface IEnumerable
    interface ITypedList
    interface ISupportInitializeNotification
    interface ISupportInitialize
Public Class DataView
Inherits MarshalByValueComponent
Implements IBindingListView, IList, ISupportInitialize, ISupportInitializeNotification, ITypedList
Public Class DataView
Inherits MarshalByValueComponent
Implements IBindingList, IList, ISupportInitialize, ITypedList
Public Class DataView
Inherits MarshalByValueComponent
Implements IBindingListView, IList, ISupportInitializeNotification, ITypedList
Public Class DataView
Inherits MarshalByValueComponent
Implements IBindingListView, ISupportInitializeNotification, ITypedList
상속
구현

예제

다음 예제에서는 열 1개와 행 5개를 사용하여 단일 DataTable 을 만듭니다. 두 개의 DataView 개체가 만들어지고 RowStateFilter 테이블 데이터의 서로 다른 뷰를 표시하도록 가 각각에 설정됩니다. 그런 다음 값이 인쇄됩니다.

using System;
using System.Xml;
using System.Data;
using System.Data.Common;
using System.Windows.Forms;

public class Form1: Form
{
    protected DataSet DataSet1;
    protected DataGrid dataGrid1;

    private void DemonstrateDataView()
    {
        // Create one DataTable with one column.
        DataTable table = new DataTable("table");
        DataColumn colItem = new DataColumn("item",
            Type.GetType("System.String"));
        table.Columns.Add(colItem);

        // Add five items.
        DataRow NewRow;
        for(int i = 0; i <5; i++)
        {
            NewRow = table.NewRow();
            NewRow["item"] = "Item " + i;
            table.Rows.Add(NewRow);
        }
        // Change the values in the table.
        table.AcceptChanges();
        table.Rows[0]["item"]="cat";
        table.Rows[1]["item"] = "dog";

        // Create two DataView objects with the same table.
        DataView firstView = new DataView(table);
        DataView secondView = new DataView(table);

        // Print current table values.
        PrintTableOrView(table,"Current Values in Table");

        // Set first DataView to show only modified
        // versions of original rows.
        firstView.RowStateFilter=DataViewRowState.ModifiedOriginal;

        // Print values.
        PrintTableOrView(firstView,"First DataView: ModifiedOriginal");

        // Add one New row to the second view.
        DataRowView rowView;
        rowView=secondView.AddNew();
        rowView["item"] = "fish";

        // Set second DataView to show modified versions of
        // current rows, or New rows.
        secondView.RowStateFilter=DataViewRowState.ModifiedCurrent
            | DataViewRowState.Added;
        // Print modified and Added rows.
        PrintTableOrView(secondView,
            "Second DataView: ModifiedCurrent | Added");
    }

    private void PrintTableOrView(DataTable table, string label)
    {
        // This function prints values in the table or DataView.
        Console.WriteLine("\n" + label);
        for(int i = 0; i<table.Rows.Count;i++)
        {
            Console.WriteLine(table.Rows[i]["item"]);
        }
        Console.WriteLine();
    }

    private void PrintTableOrView(DataView view, string label)
    {

        // This overload prints values in the table or DataView.
        Console.WriteLine("\n" + label);
        for(int i = 0; i<view.Count;i++)
        {
            Console.WriteLine(view[i]["item"]);
        }
        Console.WriteLine();
    }
}
Private Sub DemonstrateDataView()
    ' Create one DataTable with one column.
    Dim table As New DataTable("table")
    Dim colItem As New DataColumn("item", _
        Type.GetType("System.String"))
    table.Columns.Add(colItem)

    ' Add five items.
    Dim NewRow As DataRow
    Dim i As Integer
    For i = 0 To 4
    
    NewRow = table.NewRow()
    NewRow("item") = "Item " & i
    table.Rows.Add(NewRow)
    Next
    table.AcceptChanges()

    ' Create two DataView objects with the same table.
    Dim firstView As New DataView(table)
    Dim secondView As New DataView(table)
    
    ' Change the values in the table.
    table.Rows(0)("item") = "cat"
    table.Rows(1)("item") = "dog"
    
    ' Print current table values.
    PrintTableOrView(table, "Current Values in Table")
        
    ' Set first DataView to show only modified versions of original rows.
    firstView.RowStateFilter = DataViewRowState.ModifiedOriginal

    ' Print values.    
    PrintTableOrView(firstView, "First DataView: ModifiedOriginal")

    ' Add one New row to the second view.
    Dim rowView As DataRowView
    rowView = secondView.AddNew()
    rowView("item") = "fish"
    ' Set second DataView to show modified versions of 
    ' current rows, or New rows.
    secondView.RowStateFilter = DataViewRowState.ModifiedCurrent _
        Or DataViewRowState.Added
    ' Print modified and Added rows.
    PrintTableOrView(secondView, _
        "Second DataView: ModifiedCurrent or Added")
End Sub
    
Overloads Private Sub PrintTableOrView( _
    ByVal view As DataView, ByVal label As String)
    Console.WriteLine(label)
    Dim i As Integer
    For i = 0 To view.count - 1
    
    Console.WriteLine(view(i)("item"))
    Next
    Console.WriteLine()
End Sub
    
Overloads Private Sub PrintTableOrView( _
    ByVal table As DataTable, ByVal label As String)
    Console.WriteLine(label)
    Dim i As Integer
    For i = 0 To table.Rows.Count - 1
    Console.WriteLine(table.Rows(i)("item"))
    Next
    Console.WriteLine()
End Sub

다음 예제에서는 LINQ to DataSet 쿼리에서 총 주문한 온라인 주문의 을 만듭니다DataView.

DataTable orders = dataSet.Tables["SalesOrderHeader"];

EnumerableRowCollection<DataRow> query =
    from order in orders.AsEnumerable()
    where order.Field<bool>("OnlineOrderFlag") == true
    orderby order.Field<decimal>("TotalDue")
    select order;

DataView view = query.AsDataView();

bindingSource1.DataSource = view;
Dim orders As DataTable = dataSet.Tables("SalesOrderHeader")

Dim query = _
    From order In orders.AsEnumerable() _
    Where order.Field(Of Boolean)("OnlineOrderFlag") = True _
    Order By order.Field(Of Decimal)("TotalDue") _
    Select order

Dim view As DataView = query.AsDataView()
bindingSource1.DataSource = view

설명

DataView 주요 기능은 Windows Forms 및 Web Forms 데이터 바인딩을 허용하는 것입니다.

또한 에서 DataView 데이터의 DataTable하위 집합을 표시하도록 를 사용자 지정할 수 있습니다. 이 기능을 사용하면 동일한 DataTable에 바인딩된 두 개의 컨트롤이 있지만 다른 버전의 데이터를 표시할 수 있습니다. 예를 들어 한 컨트롤은 테이블의 모든 행을 표시하는 에 바인딩 DataView 될 수 있으며, 두 번째 컨트롤은 에서 DataTable삭제된 행만 표시하도록 구성될 수 있습니다. 에 DataTable 속성도 있습니다 DefaultView . 그러면 테이블의 기본값 DataView 이 반환됩니다. 예를 들어 테이블에 사용자 지정 뷰를 만들려면 에서 반환DefaultViewDataView 에 를 설정합니다RowFilter.

필터링되고 정렬된 데이터 보기를 만들려면 및 Sort 속성을 설정합니다RowFilter. 그런 다음 속성을 사용하여 Item[] 단일 DataRowView를 반환합니다.

및 메서드를 사용하여 행 집합에서 추가 및 Delete 삭제할 AddNew 수도 있습니다. 이러한 메서드를 사용하는 경우 속성은 RowStateFilter 삭제된 행 또는 새 행만 에 의해 표시 DataView되도록 지정하도록 설정할 수 있습니다.

참고

에 대한 DataView정렬 조건을 명시적으로 지정하지 않으면 의 DataRowView 개체는 에 DataView 해당하는 DataRowDataTable.RowsDataRowCollectionDataView의 인덱스 기준으로 정렬됩니다.

LINQ to DataSet 개발자는 LINQ를 사용하여 를 통해 복잡하고 강력한 쿼리를 DataSet 만들 수 있습니다. 그러나 LINQ to DataSet 쿼리는 바인딩 시나리오에서 쉽게 사용할 수 없는 개체의 DataRow 열거형을 반환합니다. DataView는 LINQ to DataSet 쿼리에서 만들 수 있으며 해당 쿼리의 필터링 및 정렬 특성을 사용합니다. LINQ to DataSet는 문자열 기반 필터링 및 정렬보다 훨씬 더 복잡하고 강력한 필터링 및 정렬 작업을 수행할 수 있는 LINQ 식 기반 필터링 및 정렬을 제공하여 DataView의 기능을 확장합니다. 자세한 내용은 데이터 바인딩 및 LINQ to DataSet을 참조하세요.

생성자

DataView()

DataView 클래스의 새 인스턴스를 초기화합니다.

DataView(DataTable)

지정된 DataView를 사용하여 DataTable 클래스의 새 인스턴스를 초기화합니다.

DataView(DataTable, String, String, DataViewRowState)

지정된 DataView , DataTable, RowFilterSort를 사용하여 DataViewRowState클래스의 새 인스턴스를 초기화합니다.

속성

AllowDelete

삭제가 허용되는지 여부를 나타내는 값을 설정하거나 가져옵니다.

AllowEdit

편집이 허용되는지 여부를 나타내는 값을 가져오거나 설정합니다.

AllowNew

AddNew() 메서드를 사용하여 새 행을 추가할 수 있는지 여부를 나타내는 값을 가져오거나 설정합니다.

ApplyDefaultSort

기본 정렬을 사용할지 여부를 나타내는 값을 가져오거나 설정합니다. 기본 정렬은 PrimaryKey에 지정된 대로 모든 기본 키에 의한 오름차순 정렬입니다.

Container

구성 요소의 컨테이너를 가져옵니다.

(다음에서 상속됨 MarshalByValueComponent)
Count

RowFilterRowStateFilter가 적용된 후에 DataView의 레코드 수를 가져옵니다.

DataViewManager

이 보기와 연결된 DataViewManager 를 가져옵니다.

DesignMode

구성 요소가 현재 디자인 모드에 있는지 여부를 나타내는 값을 가져옵니다.

(다음에서 상속됨 MarshalByValueComponent)
Events

이 구성 요소에 연결된 이벤트 처리기의 목록을 가져옵니다.

(다음에서 상속됨 MarshalByValueComponent)
IsInitialized

구성 요소가 초기화되었는지 여부를 나타내는 값을 가져옵니다.

IsOpen

데이터 원본이 현재 열려 있고 DataTable에 데이터의 보기를 표시하고 있는지 여부를 나타내는 값을 가져옵니다.

Item[Int32]

지정된 테이블에서 데이터의 행을 가져옵니다.

RowFilter

DataView에서 표시할 행을 필터링하는 데 사용하는 식을 가져오거나 설정합니다.

RowStateFilter

DataView에 사용되는 행 상태 필터를 가져오거나 설정합니다.

Site

구성 요소의 사이트를 가져오거나 설정합니다.

(다음에서 상속됨 MarshalByValueComponent)
Sort

DataView에 대한 정렬 열 및 정렬 순서를 가져오거나 설정합니다.

Table

소스 DataTable을 가져오거나 설정합니다.

메서드

AddNew()

DataView에 새 행을 추가합니다.

BeginInit()

폼에 사용되거나 다른 구성 요소에서 사용하는 DataView의 초기화를 시작합니다. 초기화는 런타임에 발생합니다.

Close()

DataView를 닫습니다.

ColumnCollectionChanged(Object, CollectionChangeEventArgs)

DataColumnCollection가 변경된 후에 발생합니다.

CopyTo(Array, Int32)

배열에 항목을 복사합니다. Web Forms 인터페이스 전용입니다.

Delete(Int32)

지정한 인덱스의 행을 삭제합니다.

Dispose()

MarshalByValueComponent에서 사용하는 모든 리소스를 해제합니다.

(다음에서 상속됨 MarshalByValueComponent)
Dispose(Boolean)

DataView 개체에서 사용하는 리소스(메모리 제외)를 삭제합니다.

EndInit()

폼에 사용되거나 다른 구성 요소에서 사용하는 DataView의 초기화를 끝냅니다. 초기화는 런타임에 발생합니다.

Equals(DataView)

지정한 DataView 인스턴스가 동일한지를 확인합니다.

Equals(Object)

지정된 개체가 현재 개체와 같은지 확인합니다.

(다음에서 상속됨 Object)
Find(Object)

지정된 정렬 키 값으로 DataView 에서 행을 찾습니다.

Find(Object[])

지정된 정렬 키 값으로 DataView 의 행을 찾습니다.

FindRows(Object)

열이 지정된 정렬 키 값과 일치하는 DataRowView 개체의 배열을 반환합니다.

FindRows(Object[])

열이 지정된 정렬 키 값과 일치하는 DataRowView 개체의 배열을 반환합니다.

GetEnumerator()

DataView에 대한 열거자를 가져옵니다.

GetHashCode()

기본 해시 함수로 작동합니다.

(다음에서 상속됨 Object)
GetService(Type)

IServiceProvider의 구현자를 가져옵니다.

(다음에서 상속됨 MarshalByValueComponent)
GetType()

현재 인스턴스의 Type을 가져옵니다.

(다음에서 상속됨 Object)
IndexListChanged(Object, ListChangedEventArgs)

DataView가 변경된 후에 발생합니다.

MemberwiseClone()

현재 Object의 단순 복사본을 만듭니다.

(다음에서 상속됨 Object)
OnListChanged(ListChangedEventArgs)

ListChanged 이벤트를 발생시킵니다.

Open()

DataView가 열립니다.

Reset()

이 속성은 내부 전용으로 예약되어 있으므로

ToString()

Component의 이름이 포함된 String을 반환합니다(있는 경우). 이 메서드는 재정의할 수 없습니다.

(다음에서 상속됨 MarshalByValueComponent)
ToTable()

기존 DataTable 의 행에 따라 새 DataView을 만들고 반환합니다.

ToTable(Boolean, String[])

기존 DataTable 의 행에 따라 새 DataView을 만들고 반환합니다.

ToTable(String)

기존 DataTable 의 행에 따라 새 DataView을 만들고 반환합니다.

ToTable(String, Boolean, String[])

기존 DataTable 의 행에 따라 새 DataView을 만들고 반환합니다.

UpdateIndex()

이 속성은 내부 전용으로 예약되어 있으므로

UpdateIndex(Boolean)

이 속성은 내부 전용으로 예약되어 있으므로

이벤트

Disposed

구성 요소의 Disposed 이벤트를 수신할 이벤트 처리기를 추가합니다.

(다음에서 상속됨 MarshalByValueComponent)
Initialized

DataView 의 초기화가 완료되면 발생합니다.

ListChanged

DataView 에서 관리하는 목록이 변경되면 발생합니다.

명시적 인터페이스 구현

IBindingList.AddIndex(PropertyDescriptor)

이 멤버에 대한 설명은 AddIndex(PropertyDescriptor)를 참조하세요.

IBindingList.AddNew()

이 멤버에 대한 설명은 AddNew()를 참조하세요.

IBindingList.AllowEdit

이 멤버에 대한 설명은 AllowEdit를 참조하세요.

IBindingList.AllowNew

이 멤버에 대한 설명은 AllowNew를 참조하세요.

IBindingList.AllowRemove

이 멤버에 대한 설명은 AllowRemove를 참조하세요.

IBindingList.ApplySort(PropertyDescriptor, ListSortDirection)

이 멤버에 대한 설명은 ApplySort(PropertyDescriptor, ListSortDirection)를 참조하세요.

IBindingList.Find(PropertyDescriptor, Object)

이 멤버에 대한 설명은 Find(PropertyDescriptor, Object)를 참조하세요.

IBindingList.IsSorted

이 멤버에 대한 설명은 IsSorted를 참조하세요.

IBindingList.RemoveIndex(PropertyDescriptor)

이 멤버에 대한 설명은 RemoveIndex(PropertyDescriptor)를 참조하세요.

IBindingList.RemoveSort()

이 멤버에 대한 설명은 RemoveSort()를 참조하세요.

IBindingList.SortDirection

이 멤버에 대한 설명은 SortDirection를 참조하세요.

IBindingList.SortProperty

이 멤버에 대한 설명은 SortProperty를 참조하세요.

IBindingList.SupportsChangeNotification

이 멤버에 대한 설명은 SupportsChangeNotification를 참조하세요.

IBindingList.SupportsSearching

이 멤버에 대한 설명은 SupportsSearching를 참조하세요.

IBindingList.SupportsSorting

이 멤버에 대한 설명은 SupportsSorting를 참조하세요.

IBindingListView.ApplySort(ListSortDescriptionCollection)

이 멤버에 대한 설명은 ApplySort(ListSortDescriptionCollection)를 참조하세요.

IBindingListView.Filter

이 멤버에 대한 설명은 Filter를 참조하세요.

IBindingListView.RemoveFilter()

이 멤버에 대한 설명은 RemoveFilter()를 참조하세요.

IBindingListView.SortDescriptions

이 멤버에 대한 설명은 SortDescriptions를 참조하세요.

IBindingListView.SupportsAdvancedSorting

이 멤버에 대한 설명은 SupportsAdvancedSorting를 참조하세요.

IBindingListView.SupportsFiltering

이 멤버에 대한 설명은 SupportsFiltering를 참조하세요.

ICollection.IsSynchronized

이 멤버에 대한 설명은 IsSynchronized를 참조하세요.

ICollection.SyncRoot

이 멤버에 대한 설명은 SyncRoot를 참조하세요.

IList.Add(Object)

이 멤버에 대한 설명은 Add(Object)를 참조하세요.

IList.Clear()

이 멤버에 대한 설명은 Clear()를 참조하세요.

IList.Contains(Object)

이 멤버에 대한 설명은 Contains(Object)를 참조하세요.

IList.IndexOf(Object)

이 멤버에 대한 설명은 IndexOf(Object)를 참조하세요.

IList.Insert(Int32, Object)

이 멤버에 대한 설명은 Insert(Int32, Object)를 참조하세요.

IList.IsFixedSize

이 멤버에 대한 설명은 IsFixedSize를 참조하세요.

IList.IsReadOnly

이 멤버에 대한 설명은 IsReadOnly를 참조하세요.

IList.Item[Int32]

이 멤버에 대한 설명은 Item[Int32]를 참조하세요.

IList.Remove(Object)

이 멤버에 대한 설명은 Remove(Object)를 참조하세요.

IList.RemoveAt(Int32)

이 멤버에 대한 설명은 RemoveAt(Int32)를 참조하세요.

ITypedList.GetItemProperties(PropertyDescriptor[])

이 멤버에 대한 설명은 GetItemProperties(PropertyDescriptor[])를 참조하세요.

ITypedList.GetListName(PropertyDescriptor[])

이 멤버에 대한 설명은 GetListName(PropertyDescriptor[])를 참조하세요.

확장 메서드

Cast<TResult>(IEnumerable)

IEnumerable의 요소를 지정된 형식으로 캐스팅합니다.

OfType<TResult>(IEnumerable)

지정된 형식에 따라 IEnumerable의 요소를 필터링합니다.

AsParallel(IEnumerable)

쿼리를 병렬화할 수 있도록 합니다.

AsQueryable(IEnumerable)

IEnumerableIQueryable로 변환합니다.

적용 대상

스레드 보안

이 형식은 다중 스레드 읽기 작업에 안전합니다. 모든 쓰기 작업을 동기화해야 합니다.

추가 정보