Режимы отображения данных в элементе управления DataGridView в Windows FormsData Display Modes in the Windows Forms DataGridView Control

DataGridView Элемент управления может отображать данные в трех различных режимах: привязанного, не связанного с данными и виртуальных.The DataGridView control can display data in three distinct modes: bound, unbound, and virtual. Выберите наиболее подходящий режим, в зависимости от ваших требований.Choose the most suitable mode based on your requirements.

СвободныеUnbound

Несвязанный режим подходит для отображения относительно небольшим объемам данных, управляемых программным способом.Unbound mode is suitable for displaying relatively small amounts of data that you manage programmatically. Не присоединять DataGridView управления непосредственно к источнику данных, как и в режиме привязки.You do not attach the DataGridView control directly to a data source as in bound mode. Вместо этого вы должны самостоятельно заполнить элемент управления, обычно с помощью DataGridViewRowCollection.Add метод.Instead, you must populate the control yourself, typically by using the DataGridViewRowCollection.Add method.

Несвязанный режим может быть особенно полезно для статических, только для чтения данных, или если вы хотите предоставить собственный код, который взаимодействует с во внешнем хранилище данных.Unbound mode can be particularly useful for static, read-only data, or when you want to provide your own code that interacts with an external data store. Если требуется, чтобы пользователи могли взаимодействовать с внешним источником данных, тем не менее, обычно используется связанный режим.When you want your users to interact with an external data source, however, you will typically use bound mode.

Пример, в котором используется только для чтения несвязанных DataGridView, см. в разделе как: Создание элемента управления DataGridView в Windows свободной формы.For an example that uses a read-only unbound DataGridView, see How to: Create an Unbound Windows Forms DataGridView Control.

привязанBound

Связанный режим подходит для управления данными, с помощью автоматического взаимодействия с хранилищем данных.Bound mode is suitable for managing data using automatic interaction with the data store. Вы можете подключить DataGridView управления непосредственно к источнику данных, задав DataSource свойство.You can attach the DataGridView control directly to its data source by setting the DataSource property. Если элемент управления с привязкой к данным, строки данных отправкой и получением без необходимости явного управления со стороны пользователя.When the control is data bound, data rows are pushed and pulled without the need of explicit management on your part. Когда AutoGenerateColumns свойство true, каждый столбец в источнике данных вызовет соответствующий столбец должен быть создан в элементе управления.When the AutoGenerateColumns property is true, each column in your data source will cause a corresponding column to be created in the control. Если вы хотите создать собственные столбцы, это свойство можно задать false и использовать DataPropertyName свойство для привязки каждого столбца при его настройке.If you prefer to create your own columns, you can set this property to false and use the DataPropertyName property to bind each column when you configure it. Это полезно в том случае, если вы хотите использовать тип столбца, отличного от типов, которые создаются по умолчанию.This is useful when you want to use a column type other than the types that are generated by default. Дополнительные сведения см. в разделе типы столбцов элемента управления DataGridView в Windows Forms.For more information, see Column Types in the Windows Forms DataGridView Control.

Пример с использованием связанного DataGridView управления, см. в разделе Пошаговое руководство: Проверка данных в Windows Forms элемента управления DataGridView.For an example that uses a bound DataGridView control, see Walkthrough: Validating Data in the Windows Forms DataGridView Control.

Можно также добавить несвязанные столбцы для DataGridView элемента управления в режиме привязки.You can also add unbound columns to a DataGridView control in bound mode. Это полезно в том случае, если вы хотите отобразить столбец кнопки или ссылки, позволяющие пользователям выполнять действия с определенными строками.This is useful when you want to display a column of buttons or links that enable users to perform actions on specific rows. Это также полезно для отображения столбцов со значениями, вычисленный на основе связанных столбцов.It is also useful to display columns with values calculated from bound columns. Можно заполнить значения ячейки для вычисляемых столбцов в обработчике CellFormatting событий.You can populate the cell values for calculated columns in a handler for the CellFormatting event. Если вы используете DataSet или DataTable как источник данных, тем не менее, может потребоваться использовать DataColumn.Expression свойство, чтобы вместо этого создать вычисляемый столбец.If you are using a DataSet or DataTable as the data source, however, you might want to use the DataColumn.Expression property to create a calculated column instead. В этом случае DataGridView управления будет рассматривать вычисляемый столбец так же, как и любой другой столбец в источнике данных.In this case, the DataGridView control will treat calculated column just like any other column in the data source.

Сортировка по несвязанных столбцов в связанном режиме не поддерживается.Sorting by unbound columns in bound mode is not supported. Если создание непривязанного столбца в режиме привязки, содержащий изменяемые пользователем значения, необходимо реализовать виртуального режима для сохранения этих значений, когда элемент управления отсортирован по связанному столбцу.If you create an unbound column in bound mode that contains user-editable values, you must implement virtual mode to maintain these values when the control is sorted by a bound column.

виртуальныйVirtual

Виртуальный режим можно реализовать собственные операции управления данными.With virtual mode, you can implement your own data management operations. Это необходимо для сохранения значений несвязанных столбцов в связанном режиме, когда элемент управления сортируется по привязанные столбцы.This is necessary to maintain the values of unbound columns in bound mode when the control is sorted by bound columns. Основной виртуальный режим, тем не менее, используется для оптимизации производительности при взаимодействии с большими объемами данных.The primary use of virtual mode, however, is to optimize performance when interacting with large amounts of data.

Присоединении DataGridView управления кэша, которыми вы управляете и код управляет отправкой и получением строк данных.You attach the DataGridView control to a cache that you manage, and your code controls when data rows are pushed and pulled. Чтобы сохранить небольшой объем памяти, кэша должен быть размер аналогичен количество отображаемых строк.To keep the memory footprint small, the cache should be similar in size to the number of rows currently displayed. Когда пользователь прокручивает новых строк в представление, код запрашивает новые данные из кэша и при необходимости очищает старые данные из памяти.When the user scrolls new rows into view, your code requests new data from the cache and optionally flushes old data from memory.

При реализации виртуального режима, необходимо отслеживать, если строку необходимо в модели данных и при откате добавления новой строки.When you are implementing virtual mode, you will need to track when a new row is needed in the data model and when to rollback the addition of the new row. Конкретная реализация этих функциональных возможностей будет зависеть от реализации модели данных и семантика транзакций модели данных; является ли область фиксации на уровне ячейки или строки.The exact implementation of this functionality will depend on the implementation of the data model and the transaction semantics of the data model; whether commit scope is at the cell or row level.

Дополнительные сведения о виртуальном режиме, см. в разделе виртуальный режим в элементе управления DataGridView Windows Forms.For more information about virtual mode, see Virtual Mode in the Windows Forms DataGridView Control. Пример, показывающий, как использовать события в виртуальном режиме, см. в разделе Пошаговое руководство: Реализация виртуального режима в Windows Forms элемента управления DataGridView.For an example that shows how to use virtual mode events, see Walkthrough: Implementing Virtual Mode in the Windows Forms DataGridView Control.

См. такжеSee also