.NET Interview Questions - Differentiate between ‘DataSet’ and ‘SQLDataReader’ in ADO.NET?
Shivprasad Koirala
Select an image from your device to upload
In this question the interviewer is expecting two points the first point is dataset is a connect architecture and datareader is a disconnected architecture. Let’s discuss both these points in detail.
In order to understand that, below is the sample code for ‘DataSet’ where you can see even after calling the “ObjConnection.Close()” the ”Foreach Loop” is still running. This indicates that the ‘DataSet’ works in Disconnected Architecture.
Similarly, below is the sample code for ‘DataReader’ where you can see that when “ObjConnection.Close()” is called then the “While Loop” does not execute and throws an error. This indicates that the ‘DataReader’ works only in Connected Architecture.
Dataset is an in-memory database with database, tables, columns and rows. While data reader is a flat table with just rows and columns
If you see the dataset object in your visual studio intellisense you should see the complete object hierarchy as shown in the below figure.
If you see the ‘sqldatareader’ in intellisense , its flat table with rows and columns as shown in the below image.