Tuesday, November 4, 2014

Difference Between DataReader, DataSet, DataAdapter and DataTable in C#

DataReader

DataReader is used to read the data from database and it is a read and forward only connection oriented architecture during fetch the data from database. DataReader will fetch the data very fast when compared with dataset. Generally we will use ExecuteReader object to bind data to datareader.

To bind DataReader data to GridView we need to write the code like as shown below:


Protected void BindGridview()
{
using (SqlConnection conn = new SqlConnection("Data Source=abc;Integrated Security=true;Initial Catalog=Test"))
{
con.Open();
SqlCommand cmd = new SqlCommand("Select UserName, First Name,LastName,Location FROM Users", conn);
SqlDataReader sdr = cmd.ExecuteReader();
gvUserInfo.DataSource = sdr;
gvUserInfo.DataBind();
conn.Close();
}
}
Holds the connection open until you are finished (don't forget to close it!).
Can typically only be iterated over once
Is not as useful for updating back to the database.

DataSet

DataSet is a disconnected orient architecture that means there is no need of active connections during work with datasets and it is a collection of DataTables and relations between tables. It is used to hold multiple tables with data. You can select data form tables, create views based on table and ask child rows over relations. Also DataSet provides you with rich features like saving data as XML and loading XML data.

protected void BindGridview()
{
    SqlConnection conn = new SqlConnection("Data Source=abc;Integrated Security=true;Initial Catalog=Test");
    conn.Open();
    SqlCommand cmd = new SqlCommand("Select UserName, First Name,LastName,Location FROM Users", conn);
    SqlDataAdapter sda = new SqlDataAdapter(cmd);
    DataSet ds = new DataSet();
    da.Fill(ds);
    gvUserInfo.DataSource = ds;
    gvUserInfo.DataBind();
}
DataAdapter

DataAdapter will acts as a Bridge between DataSet and database. This dataadapter object is used to read the data from database and bind that data to dataset. Dataadapter is a disconnected oriented architecture. Check below sample code to see how to use DataAdapter in code:

protected void BindGridview()
{
    SqlConnection con = new SqlConnection("Data Source=abc;Integrated Security=true;Initial Catalog=Test");
    conn.Open();
    SqlCommand cmd = new SqlCommand("Select UserName, First Name,LastName,Location FROM Users", conn);
    SqlDataAdapter sda = new SqlDataAdapter(cmd);
    DataSet ds = new DataSet();
    da.Fill(ds);
    gvUserInfo.DataSource = ds;
    gvUserInfo.DataBind();
}
Lets you close the connection as soon it's done loading data, and may even close it for you automatically
All of the results are available in memory
You can iterate over it as many times as you need, or even look up a specific record by index
Has some built-in faculties for updating back to the database.

DataTable 

DataTable represents a single table in the database. It has rows and columns. There is no much difference between dataset and datatable, dataset is simply the collection of datatables.

protected void BindGridview()
{
     SqlConnection con = new SqlConnection("Data Source=abc;Integrated Security=true;Initial Catalog=Test");
     conn.Open();
     SqlCommand cmd = new SqlCommand("Select UserName, First Name,LastName,Location FROM Users", conn);
     SqlDataAdapter sda = new SqlDataAdapter(cmd);
     DataTable dt = new DataTable();
     da.Fill(dt);
     gridview1.DataSource = dt;
     gvidview1.DataBind();
}
  

Important Command Ado.Net

With the release of the .NET Framework, Microsoft introduced a new data access model, called ADO.NET.The five major objects in ADO.NET are:

Obects Description
Connection The Connection object is responsible for establishing and maintaining the connection to the data source.
Command The Command object stores the query that is to be sent to the data source, and any applicable parameters.
DataReader The DataReader object provides fast, forward-only,readonly object. It is connection oriented.
DataSet           The DataSet object is the collection of objects.It contains DataTable,DataRow,DataRelation, etc.It provides a storage mechanism for disconnected data. It is as an in-memory repository to store data that has been retrieved.
DataAdapter The DataAdapter object works as a bridge between the DataSet and the data source. The DataAdapter is responsible for retrieving the data from the Command object and populating the DataSet with the data returned.It uses the Fill method to populate the DataSet.



If you are working with Microsoft SQL server then you must include the following namespace:

System.Data
System.Data.SqlClient
Connection Objects

The main use of connection object is to provide connection to a data source. A connection object does not fetch or update data, it does not execute queries, and it does not contain the results of queries.It is a place where you can provide the connection string.

Creating Connection:
SqlConnection conObject = new SqlConnection
("Data Source=ServerName; Initial Catalog=DatabaseName; Integrated Security=True");

Important Properties of Connection Object.

NAME Description
ConnectionString Gets or sets the string used to open the connection.
Database Read only. Gets the name of the current database after a connection is opened .
DataSource Read only. Gets the name of the database server to which it is connected.
State Read only. Gets the state of the connection.
Command Objects

Command object is used to execute SQL statements and stored procedures against a database. Command objects contain the necessary information to execute SQL statements, stored procedures, functions, and so on.

Important Properties of Command Object.

NAME DESCRIPTION
CommandText Set this to any valid SQL statement or the name of any valid stored procedure. The CommandType value determines the manner of execution.
CommandType Set to either SQL statement or StoredProcedure
Connection Set this to the connection object.
Parameters The command’s parameters collection. When running parameterized queries or stored procedures, you must add parameterobjects to this collection.
Transaction The SqlTransaction within which the SqlCommand executes.

Important Methods of Command Object.

NAME DESCRIPTION
ExecuteNonQuery This method is used,If you are using insert,update,delete SQL statement.Its return type is Integer.This indicates the no of effected records.
ExecuteReader This method is used,If you are using Select SQL statement.Its return type is DataReader.
ExecuteScalar If you need to return a single value from a database query, you can use the ExecuteScalar method. This method always returns the value of the first column from the first row of a resultset.Its return type is Object.
ExecuteXMLReader Returns XML formatted data. Returns a System.Xml.XmlReader object.
DataReader Object

The DataReader Object provides a connection oriented data access to the Data Sources. DataReader Object is fast, forward-only, read-only retrieval of query results from the Data Sources It is not used to update the data.When we started to read from a DataReader it should always be open and positioned prior to the first record. The Read() method in the DataReader is used to read the rows from DataReader and it always moves forward to a new valid row, if any row exist .

Important Properties of DataReader Object.

NAME DESCRIPTION
Connection Gets the Connection associated with the DataReader.
FieldCount Gets the number of columns in the current row.
HasRows Gets a value that indicates whether the DataReader contains one or more rows.
IsClosed Retrieves a Boolean value that indicates whether the specified DataReader instance has been closed or not.
RecordsAffected Gets the number of rows affected, inserted, or deleted by execution of the Transact-SQL statement.
Important Methods of DataReader Object.

NAME DESCRIPTION
Close Closes the DataReader object.
NextResult Advances the data reader to the next result, when reading the results of batch Transact-SQL statements.
Read Advances the DataReader to the next record.
GetValue Gets the value of the specified column
The DataReader cannot be created directly from code, they can created only by calling the ExecuteReader method of a Command Object.

Example:

string connString = "some valid conn string";
SqlConnection connection = new SqlConnection(connString);
connection.Open();
SqlCommand cmd = new SqlCommand();
cmd.Connection = connection;
cmd.CommandType = CommandType.Text;
cmd.CommandText = "SELECT empID, empName FROM Employees";
SqlDataReader reader= cmd.ExecuteReader();
GridView1.DataSource = reader;
GridView1.DataBind ();
connection.Close();

Working with ADO.NET disconnected classes

The DataTable object represents tabular data as rows, columns, and constraints. You generally get a DataTable object by connecting to the database and returning table data but we can also create it by using DataTable class.

Example:

DataTable dt = new DataTable();
DataColumn dc = new DataColumn();
dc.ColumnName = "ProductID";
dc.DataType = typeof(int);
dt.Columns.Add(dc);
DataColumn dc2 = new DataColumn();
dc2.ColumnName = "ProductName";
dc2.DataType = typeof(string);
dt.Columns.Add(dc2);
dt.Rows.Add(new object[] { "1","CareerRide" });
GridView1.DataSource = dt;
GridView1.DataBind ();

Working with DataSet Object

Dataset is a disconnected, in-memory representation of data. It can contain multiple data table from different database.

Example:

string connString = "some valid conn string";
SqlConnection connection = new SqlConnection(connString);
using (SqlCommand cmd = new SqlCommand("Select * from Products", connection))
{
            SqlDataAdapter da = new SqlDataAdapter(cmd);
            DataSet ds = new DataSet();
            da.Fill(ds);
            GridView1.DataSource = ds;
            GridView1.DataBind();
}