Convert Data Reader To Datatable
In this article we will learn how we can convert Microsoft ADOMD data reader to datatable. As you all know a data reader is the most efficient way for looping through the data. Performance wise a data reader is faster than any of the other way like data adapter and cell set in MDX result. So in few situations you may need to convert this data reader to a data table. Here in this post we will discuss how we can convert it. I hope you will like it.
Background
For the past few months I have been working with Microsoft ADOMD data sources. And I have written some article also that will describe the problems I have encountered so far. If you are new to ADOMD I strongly recommend that read my previous articles that you may find useful when you work with ADOMD data sources. You can find those article links here: ADOMD Data Sources
Why
You might think, why I am not using other two ways (data adapter and cell set). I will answer it here. I am handling large set of data, so when I use data adapter and cell set it was bit slow to get the output. So I was just checking the performance by using data reader. It was fast enough when I use data reader. So we can order these three as following by performance.
Data reader >> Data Adapter >> Cell Set
Using the code
The following is the function that does what was explained above.
[csharp]
#region Convert Datareader toDatatable
/// <summary>
/// Convert Datareader toDatatable
/// </summary>
/// <param name="query"></param>
/// <param name="myConnection"></param>
public DataTable ConvertDataReaderToDataTable(string query, string myConnection)
{
AdomdConnection conn = new AdomdConnection(myConnection);
try
{
try
{
conn.Open();
}
catch (Exception)
{
}
using (AdomdCommand cmd = new AdomdCommand(query, conn))
{
AdomdDataReader rdr;
cmd.CommandTimeout = connectionTimeout;
using (AdomdDataAdapter ad = new AdomdDataAdapter(cmd))
{
DataTable dtData = new DataTable("Data");
DataTable dtSchema = new DataTable("Schema");
rdr = cmd.ExecuteReader();
if (rdr != null)
{
dtSchema = rdr.GetSchemaTable();
foreach (DataRow schemarow in dtSchema.Rows)
{
dtData.Columns.Add(schemarow.ItemArray[0].ToString(), System.Type.GetType(schemarow.ItemArray[5].ToString()));
}
while (rdr.Read())
{
object[] ColArray = new object[rdr.FieldCount];
for (int i = 0; i < rdr.FieldCount; i++)
{
if (rdr[i] != null) ColArray[i] = rdr[i];
}
dtData.LoadDataRow(ColArray, true);
}
rdr.Close();
}
return dtData;
}
}
}
catch (Exception)
{
throw;
}
finally
{
conn.Close(false);
}
}
#endregion;
[/csharp]
Here we are creating two data table dtData and dtSchema where dtData is for binding the data and dtSchema is for binding the schema.
Creating data tables
[csharp]
DataTable dtData = new DataTable("Data");
DataTable dtSchema = new DataTable("Schema");
[/csharp]
Execute data reader
Now we will execute the reader as follows.
[csharp]
rdr = cmd.ExecuteReader();
[/csharp]
Get the schema
To generate the schema, we can call the function GetSchemaTable() which is a part of your data reader.
To use this function, you must include Microsoft.AnalysisServices.AdomdClient.dll
Adding the columns headers to the dtData
The next thing is to add the header names to the data table dtData.
[csharp]
foreach (DataRow schemarow in dtSchema.Rows)
{
dtData.Columns.Add(schemarow.ItemArray[0].ToString(), System.Type.GetType(schemarow.ItemArray[5].ToString()));
}
[/csharp]
Load the data to dtData
To load the data, we are using a function LoadDataRow() which expects an object as parameter. This will find and updates a specific row, if the matching row is not found, it will create an another row with the given values.
[csharp]
object[] ColArray = new object[rdr.FieldCount];
for (int i = 0; i < rdr.FieldCount; i++)
{
if (rdr[i] != null) ColArray[i] = rdr[i];
}
dtData.LoadDataRow(ColArray, true);
[/csharp]
Conclusion
Have you ever gone through this kind of requirement. Did I miss anything that you may think which is needed?. I hope you liked this article. Please share me your valuable suggestions and feedback.
Your turn. What do you think?
A blog isn’t a blog without comments, but do try to stay on topic. If you have a question unrelated to this post, you’re better off posting it on C-Sharp Corner, Stack Overflow, Asp.Net Forums or Code Project instead of commenting here. Tweet or email me a link to your question there and I’ll definitely try to help if I am able to.
Kindest Regards
Sibeesh Venu