Sibeesh Passion

Top Menu

  • Home
  • Search
  • About
  • Privacy Policy

Main Menu

  • Articles
    • Azure
    • .NET
    • IoT
    • JavaScript
    • Career Advice
    • Interview
    • Angular
    • Node JS
    • JQuery
    • Knockout JS
    • Jasmine Framework
    • SQL
    • MongoDB
    • MySQL
    • WordPress
  • Contributions
    • Medium
    • GitHub
    • Stack Overflow
    • Unsplash
    • ASP.NET Forum
    • C# Corner
    • Code Project
    • DZone
    • MSDN
  • Social Media
    • LinkedIn
    • Facebook
    • Instagram
    • Twitter
  • YouTube
    • Sibeesh Venu
    • Sibeesh Passion
  • Awards
  • Home
  • Search
  • About
  • Privacy Policy

logo

Sibeesh Passion

  • Articles
    • Azure
    • .NET
    • IoT
    • JavaScript
    • Career Advice
    • Interview
    • Angular
    • Node JS
    • JQuery
    • Knockout JS
    • Jasmine Framework
    • SQL
    • MongoDB
    • MySQL
    • WordPress
  • Contributions
    • Medium
    • GitHub
    • Stack Overflow
    • Unsplash
    • ASP.NET Forum
    • C# Corner
    • Code Project
    • DZone
    • MSDN
  • Social Media
    • LinkedIn
    • Facebook
    • Instagram
    • Twitter
  • YouTube
    • Sibeesh Venu
    • Sibeesh Passion
  • Awards
  • Linux Azure Function Isolated Dot Net 9 YAML Template Deployment

  • Build, Deploy, Configure CI &CD Your Static Website in 5 mins

  • Post Messages to Microsoft Teams Using Python

  • Get Azure Blob Storage Blob Metadata Using PowerShell

  • Deploy .net 6 App to Azure from Azure DevOps using Pipelines

Microsoft ADOMDSSAS
Home›Microsoft ADOMD›Convert Data Reader To Datatable

Convert Data Reader To Datatable

By SibeeshVenu
November 17, 2015
2069
0
Share:
Convert data reader to data table

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.

Convert data reader to data table

Convert data reader to data table

[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

TagsCSharpData readerData reader to Data tableGenerate table schemaGetSchemaTableLoadDataRowSSAS
Previous Article

Disable Dates In Datepicker

Next Article

One Million Read Count In C-Sharp Corner

0
Shares
  • 0
  • +
  • 0
  • 0
  • 0

SibeeshVenu

I am Sibeesh Venu, an engineer by profession and writer by passion. Microsoft MVP, Author, Speaker, Content Creator, Youtuber, Programmer.

Related articles More from author

  • Excel Export In MDX
    .NETASP.NETMDX QuerySQL

    Export MDX Result As Excel

    October 28, 2015
    By SibeeshVenu
  • Caching In MVC
    .NETASP.NETMVC

    Caching In MVC

    October 31, 2015
    By SibeeshVenu
  • .NETASP.NETC#Interview

    C sharp Interview Questions And Answers

    October 24, 2015
    By SibeeshVenu
  • MDX QuerySSAS

    Find Datatype Of Each Measures In SSAS MDX Queries

    February 22, 2016
    By SibeeshVenu
  • Compression_References
    .NETASP.NET

    Programmatically Extract or Unzip Zip,Rar Files And Check

    February 25, 2016
    By SibeeshVenu
  • Select NuGet Package
    .NETASP.NETMVC Grid

    Using MVC Grid In MVC

    December 11, 2015
    By SibeeshVenu
0

My book

Asp Net Core and Azure with Raspberry Pi Sibeesh Venu

YouTube

MICROSOFT MVP (2016-2022)

profile for Sibeesh Venu - Microsoft MVP

Recent Posts

  • Linux Azure Function Isolated Dot Net 9 YAML Template Deployment
  • Build, Deploy, Configure CI &CD Your Static Website in 5 mins
  • Easily move data from one COSMOS DB to another
  • .NET 8 New and Efficient Way to Check IP is in Given IP Range
  • Async Client IP safelist for Dot NET
  • Post Messages to Microsoft Teams Using Python
  • Get Azure Blob Storage Blob Metadata Using PowerShell
  • Deploy .net 6 App to Azure from Azure DevOps using Pipelines
  • Integrate Azure App Insights in 1 Minute to .Net6 Application
  • Azure DevOps Service Connection with Multiple Azure Resource Group

Tags

Achievements (35) Angular (14) Angular 5 (7) Angular JS (15) article (10) Article Of The Day (13) Asp.Net (14) Azure (65) Azure DevOps (10) Azure Function (10) Azure IoT (7) C# (17) c-sharp corner (13) Career Advice (11) chart (11) CSharp (7) CSS (7) CSS3 (6) HighChart (10) How To (9) HTML5 (10) HTML5 Chart (11) Interview (6) IoT (11) Javascript (10) JQuery (82) jquery functions (9) JQWidgets (15) JQX Grid (17) Json (7) Microsoft (8) MVC (20) MVP (9) MXChip (7) News (18) Office 365 (7) Products (10) SQL (20) SQL Server (15) Visual Studio (10) Visual Studio 2017 (7) VS2017 (7) Web API (12) Windows 10 (7) Wordpress (9)
  • .NET
  • Achievements
  • ADO.NET
  • Android
  • Angular
  • Arduino
  • Article Of The Day
  • ASP.NET
  • Asp.Net Core
  • Automobile
  • Awards
  • Azure
  • Azure CDN
  • azure devops
  • Blockchain
  • Blog
  • Browser
  • C-Sharp Corner
  • C#
  • Career Advice
  • Code Snippets
  • CodeProject
  • Cognitive Services
  • Cosmos DB
  • CSS
  • CSS3
  • Data Factory
  • Database
  • Docker
  • Drawings
  • Drill Down Chart
  • English
  • Excel Programming
  • Exporting
  • Facebook
  • Fun
  • Gadgets
  • GitHub
  • GoPro
  • High Map
  • HighChart
  • How to
  • HTML
  • HTML5
  • Ignite UI
  • IIS
  • Interview
  • IoT
  • JavaScript
  • JQuery
  • jQuery UI
  • JQWidgets
  • JQX Grid
  • Json
  • Knockout JS
  • Linux
  • Machine Learning
  • Malayalam
  • Malayalam Poems
  • MDX Query
  • Microsoft
  • Microsoft ADOMD
  • Microsoft MVP
  • Microsoft Office
  • Microsoft Technologies
  • Microsoft Windows
  • Microsoft Windows Server
  • Mobile
  • MongoDB
  • Monthly Winners
  • MVC
  • MVC Grid
  • MySQL
  • News
  • Node JS
  • npm
  • Number Conversions
  • October 2015
  • Office 365
  • Office Development
  • One Plus
  • Outlook
  • Page
  • PHP
  • Poems
  • PowerShell
  • Products
  • Q&A
  • Raspberry PI
  • React
  • SEO
  • SharePoint
  • Skype
  • Social Media
  • Software
  • Spire.Doc
  • Spire.PDF
  • Spire.XLS
  • SQL
  • SQL Server
  • SSAS
  • SSMS
  • Storage In HTML5
  • Stories
  • Third Party Software Apps
  • Tips
  • Tools
  • Translator Text
  • Uncategorized
  • Unit Testing
  • UWP
  • VB.Net
  • Videos
  • Virtual Machine
  • Visual Studio
  • Visual Studio 2017
  • Wamp Server
  • Web API
  • Web Platform Installer
  • Webinars
  • WebMatrix
  • Windows 10
  • Windows 7
  • Windows 8.1
  • Wordpress
  • Writing

ABOUT ME

I am Sibeesh Venu, an engineer by profession and writer by passion. Microsoft MVP, Author, Speaker, Content Creator, Youtuber, Programmer. If you would like to know more about me, you can read my story here.

Contact Me

  • info@sibeeshpassion.com

Pages

  • About
  • Search
  • Privacy Policy
  • About
  • Search
  • Privacy Policy
© Copyright Sibeesh Passion 2014-2025. All Rights Reserved.
Go to mobile version