This documentation is archived and is not being maintained.

EnumerableRowCollectionExtensions.Select<TRow, S> Method

Projects each element of an EnumerableRowCollection<TRow> into a new form. This API supports the .NET Framework infrastructure and is not intended to be used directly from your code.

Namespace:  System.Data
Assembly:  System.Data.DataSetExtensions (in System.Data.DataSetExtensions.dll)

public static EnumerableRowCollection<S> Select<TRow, S>(
	this EnumerableRowCollection<TRow> source,
	Func<TRow, S> selector

Type Parameters


The type of the row elements in source, typically DataRow.


The type that TRow will be transformed into.


Type: System.Data.EnumerableRowCollection<TRow>
An EnumerableRowCollection<TRow> containing the DataRow elements to invoke a transform function upon.
Type: System.Func<TRow, S>
A transform function to apply to each element.

Return Value

Type: System.Data.EnumerableRowCollection<S>
An EnumerableRowCollection<TRow> whose elements are the result of invoking the transform function on each element of source.

Usage Note

In Visual Basic and C#, you can call this method as an instance method on any object of type EnumerableRowCollection<TRow>. When you use instance method syntax to call this method, omit the first parameter. For more information, see Extension Methods (Visual Basic) or Extension Methods (C# Programming Guide).

This method is implemented by using deferred execution. The immediate return value is an object that stores all the information that is required to perform the action. The query represented by this method is not executed until the object is enumerated either by calling its GetEnumerator method directly or by using foreach in Visual C# or For Each in Visual Basic.

This projection method requires the transform function, selector, to produce one value for each value in the source sequence, source. If selector returns a value that is itself a collection, it is up to the consumer to traverse the subsequences manually.

.NET Framework

Supported in: 4, 3.5

.NET Framework Client Profile

Supported in: 4, 3.5 SP1

Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2

The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.