Working with DataSets

Access and Manipulate Data – Using DataSets

In this tutorial you will learn about Using DataSets, Populating a DataSet From a Database, Moving Around in DataSets and Retrieving Data, Using Strongly Typed DataSets, DataSets With Multiple Tables.

Populating a DataSet from a Database

As already discussed DataSets do not contain any data when they are created. The user must fill the data in to the DataSet separately. We have already seen that there are several methods of filling a DataSet with data. DataSets can be created using the Visual Studio Design in which case TableAdapters are also created.

Filling a DataSet using a TableAdapter

  1. Create a new project in Visual Basic IDE. 
  2. On the Database Explorer click the icon for creating new data connection and 
  3. Choose the SQL Server file.
  4. Establish the connection and you should be seeing the database objects on the window.
  5. In the solution Explorer click on the project name and
  6. Choose add an item option.
  7. In the dialog box that opens choose DataSet item and
  8. Name it as ds and click ok.
  9. You will see the DataSet item added to the solution and also
  10. A blank screen will be seen.
  11. From the Database explorer drag and drop the table ProductCategory.
  12. Choose ‘not’ in the message box that asks your permission to add the datafile as a project data.
  13. Now right click on the Form1 and
  14. Choose the option to see the code window.
  15. Type the following codes to fill the DataSet
  1. Dim ProductCategoryTableAdapter As New dsTableAdapters.ProductCategoryTableAdapter() 
  2. Dim ProductCategoryDataSet As New ds ProductCategoryTableAdapter.Fill(ProductCategoryDataSet.ProductCategory)

You can also populate a DataSet using a SqlDataAdapter or an OleDbDataAdapter. The method of doing this is same in both the cases. We shall now see how a DataSet is filled by using a SqlDataAdapter. You have to

  1. Create a SqlConnection object. SqlDatAdapter object.
  2. The SqlConnection object needs connection string as an argument and the SqlDataAdapter requires the SQL Statement and Connection Object as an argument.
  3. The ConnectString gives details about the Database Server, Initial Catalogue, connection type, userid and password.
  4. A typical connection string could look like this:
  1. data source=sql.domain.no; 
  2. initial catalog=xxxxx; 
  3. User ID=xxxxx;pwd=xxxxx; 
  4. Integrated Security=SSPI

Code for filling the DataSet is given below:

  1. Dim SQLStr As String 
  2. Dim ConStr As String 
  3. SQLStr = "SELECT Name FROM production.ProductCategory" 
  4. ConStr = "data source=sql.domain.no; initial catalog=xxxxx; User ID=xxxxx;pwd=xxxxx; Integrated Security=SSPI" 
  5. Dim sqlConn As New System.Data.SqlClient.SqlConnection(ConStr) 
  6. Dim ds As New DataSet 
  7. Dim SQLAdapter As New System.Data.SqlClient.SqlDataAdapter(SQLStr, ConStr) 
  8. SQLAdapter.Fill(ds)

New rows can be added manually to the data set as in the case of a data-entry. In this case the user has to first create a DataSet, a DataTabale, and a DataRow. Then he must populate the DataRow manually by supplying the value for each row and then add these rows to the DataSet. It should be remembered that there is no underlying data store that supplies data in this case. The code for the activity is given below:

  1. Dim dsNew As New DataSet 
  2. Dim t As New DataTable 
  3. Dim tr As DataRow = dsNew.Tables("T").NewRow 
  4. tr("Name") = "Aviation Gears" 
  5. dsNew.Tables("T").Rows.Add(tr)

You can also populate a DataSet by reading from an WML file. The code listing is given below:

  1. Dim dsXML As New DataSet() 
  2. dsXML.ReadXml("XmlFilePath and Name")

The user can also create a new DataSet and merge it with any existing DataSet. This opetaion is illustrated by the code given below:

  1. Dim dsXML As New DataSet() 
  2. Dim dsCopy As New DataSet 
  3. dsXML.ReadXml("XmlFilePath and Name") 
  4. dsCopy.Merge(dsXML, True, MissingSchemaAction.AddWithKey)

Moving Around in DataSet and Retrieving Data

In the above sections we have seen how to create a DataSet, how to populate it etc. In the following sections we shall see how to retrieve data from a DataSet. Remember, we stated that there is no current row in a DataSet? So any row can be accessed directly by just mentioning its position? Let us add to this the fact that a DataSet can contain as many tables as required and the user can also create objects that show the relationships that exist and the constraints that are imposed on them. Thus a DataSet can be a very complex data store. Let us understand the process of navigating the DataSet by the following example.

You can write code to go to the first record of the table, go one record forward or backward and also go to the last record. We shall use the BindingContext to do this. Look at the following code:

Click here to view sample code

Retrieving data from DataSets is easy. The data in the DataSet can be displayed in a grid and a script can be written to enable the user browse through the data. The sample code illustrates this.

  1. Imports system.Data 
  2. Public Class Form1 
  3. Dim ProductDataSet As ds 
  4. Private Sub DataLoad() 
  5. Dim ProductTableAdapter As New dsTableAdapters.ProductTableAdapter() 
  6. ProductDataSet = New ds ProductTableAdapter.Fill(ProductDataSet.Product) 
  7. End Sub

The code that is given below will make navigation within the data set.

Click here to view sample code

{mospagebreak}

Using Strongly Typed DataSets

A strongly typed DataSet can ensure that the CLR and .NET framework know at design time the type of data that is to be stored in the location specified by the DataSet. Unless a strongly typed data classes are set up, the compiler needs to take extra time at runtime to determine where to place the incoming data and how to convert it into the destination data type. The performance overhead is increased substantially relative to the strongly typed DataSets

Strongly typed DataSets can be created in two ways. In the menu click the Data MainMenu and choose the submenu Add New Data Source …. And click on this. The Data Source Configuration Wizard opens. In the Wizard choose Database and click next.

In the second screen choose the data file (*.mdf) by clicking new connection and click next.

Click next to continue.

Choose the tables that you want to add and click on Finish. This will create a typed data set.

The screenshot shown below shows the new Strongly typed DataSet that was created.

In the next method, click the project in the solution explorer and choose the add new item from the context sensitive menu and in the dialog box choose the data set and click add.

The DataSet is created. The screenshot shows the toolbar with dataset tools. You can drag and drop any of the tools and configure. This also will create a typed dataset.

DataSets With Multiple Tables

In most situations a typical DataSet will be populated with multiple tables. By default these tables will not have any relationship defined. The user will also not have any constraints defined. Tables can be referenced by table name or serial number. For example a Customer table which was added as a third table can be referenced as under:

  1. CustomerDataTable = MultiTableDataSet.Tables(3)

or by the following statement:

  1. CustomerDataTable = MultiTableDataSet.Tables("Customer")

The following screenshot shows the structure of a DataSet with multiple tables:

[catlist id=175].

Related posts