DataSet.Load Method (IDataReader, LoadOption, FillErrorEventHandler, DataTable[])


The .NET API Reference documentation has a new home. Visit the .NET API Browser on to see the new experience.

Fills a DataSet with values from a data source using the supplied IDataReader, using an array of DataTable instances to supply the schema and namespace information.

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

abstract Load : 
        reader:IDataReader *
        loadOption:LoadOption *
        errorHandler:FillErrorEventHandler *
        [<ParamArrayAttribute>] tables:DataTable[] -> unit
override Load : 
        reader:IDataReader *
        loadOption:LoadOption *
        errorHandler:FillErrorEventHandler *
        [<ParamArrayAttribute>] tables:DataTable[] -> unit


Type: System.Data.IDataReader

An IDataReader that provides one or more result sets.

Type: System.Data.LoadOption

A value from the LoadOption enumeration that indicates how rows already in the DataTable instances within the DataSet will be combined with incoming rows that share the same primary key.

Type: System.Data.FillErrorEventHandler

A FillErrorEventHandler delegate to call when an error occurs while loading data.

Type: System.Data.DataTable[]

An array of DataTable instances, from which the Load method retrieves name and namespace information.

The Load method provides a technique for filling a single DataTable with data, retrieved from an IDataReader instance. This method provides the same functionality, but allows you to load multiple result sets from an IDataReader into multiple tables within a DataSet.


The load operation will fail with an InvalidOperationException if any of the source data columns in the incoming reader are computed columns.

The loadOption parameter allows you to specify how you want the imported data to interact with existing data, and can be any of the values from the LoadOption enumeration. See the documentation for the DataTableLoad method for more information on using this parameter.

The errorHandler parameter is a FillErrorEventHandler delegate that refers to a procedure that is called when an error occurs while loading data. The FillErrorEventArgs parameter passed to the procedure provides properties that allow you to retrieve information about the error that occurred, the current row of data, and the DataTable being filled. Using this delegate mechanism, rather than a simpler try/catch block, allows you to determine the error, handle the situation, and continue processing if you like. The FillErrorEventArgs parameter supplies a Continue property: set this property to true to indicate that you have handled the error and wish to continue processing; set the property to false to indicate that you wish to halt processing. Be aware that setting the property to false causes the code that triggered the problem to throw an exception.

The tables parameter allows you to specify an array of DataTable instances, indicating the order of the tables corresponding to each result set loaded from the reader. The Loadmethod fills each supplied DataTable instance with data from a single result set from the source data reader. After each result set, the Loadmethod moves on to the next result set within the reader, until there are no more result sets.

The name resolution scheme for this method is the same as that followed by the Fill method of the DbDataAdapter class.

The following example adds a table to a DataSet, and then attempts to use the Load method to load data from a DataTableReader that contains an incompatible schema. Rather than trapping the error, this example uses a FillErrorEventHandler delegate to investigate and handle the error. The output is displayed in the console window.

No code example is currently available or this language may not be supported.

.NET Framework
Available since 2.0
Return to top