Using FusionCharts with ASP.NET 2.0 (VB.NET) > Plotting data from a database |
In this section, we'll show you how to use FusionCharts and ASP.NET to plot charts from data contained in a database. We'll create a pie chart to show "Production by Factory" using:
For the sake of ease, we'll use an Access Database. The database is present in Download Package > Code > VB_NET > DB folder. You can, however, use any database with FusionCharts including MS SQL, Oracle, mySQL etc. Before you go further with this page, we recommend you to please see the previous section "Basic Examples" as we start off from concepts explained in that page. The code examples contained in this page are present in Download Package > Code > VB_NET > DBExample folder. The Access database is present in Download Package > Code > VB_NET > DB. |
Database Structure |
Before we code the ASP.NET pages to retrieve data, let's quickly have a look at the database structure. |
![]() |
The database contains just 2 tables:
For demonstration, we've fed some dummy data in the database. Let's now shift our attention to the ASP.NET page that will interact with the database, fetch data and then render a chart. |
Building the ASP.NET Page for dataXML Method |
The ASP.NET page for dataXML method example is named as BasicDBExample.aspx (in DBExample folder). It contains the following code (GetFactorySummaryChartHtml() method from code behind page also reproduced below): |
<%@ Page Language="VB" AutoEventWireup="false" CodeFile="BasicDBExample.aspx.vb" Inherits="DBExample_BasicDBExample" %> |
Code Behind page: Imports InfoSoftGlobal Imports System.Text Imports DataConnection Partial Class DBExample_BasicDBExample Inherits System.Web.UI.Page Public Function GetFactorySummaryChartHtml() As String 'In this example, we show how to connect FusionCharts to a database. 'For the sake of ease, we've used an Access database which is present in '../DB/FactoryDB.mdb. It just contains two tables, which are linked to each 'other. 'xmlData will be used to store the entire XML document generated Dim xmlData As New StringBuilder() 'Generate the chart element xmlData.Append("<chart caption='Factory Output report' subCaption='By Quantity' pieSliceDepth='30' showBorder='1' formatNumberScale='0' numberSuffix=' Units'>") 'create recordset to get details for the factories Dim factoryQuery As String = "select a.FactoryId, a.FactoryName, sum(b.Quantity) as TotQ from .Factory_Master a, Factory_Output b where a.FactoryId=b.FactoryID group by a.FactoryId, a.FactoryName" ' Dim oRs As New DbConn(factoryQuery) 'Iterate through each record While oRs.ReadData.Read() 'Generate <set label='..' value='..' /> xmlData.Append("<set label='" & oRs.ReadData("FactoryName").ToString() & "' value='" & oRs.ReadData("TotQ").ToString & "' />") End While ' oRs.ReadData.Close() 'Close chart element xmlData = (xmlData &"</chart>") 'Create the chart - Pie 3D Chart with data from xmlData Return InfoSoftGlobal.FusionCharts.RenderChart("../FusionCharts/Pie3D.swf", "", xmlData, "FactorySum", "600", "300", False, False) End Function End Class |
The following actions are taking place in this code:
When you now run the code, you'll get an output as under: |
![]() |
Converting the example to use dataURL method |
Let's now convert this example to use dataURL method. As previously explained, in dataURL mode, you need two pages:
The pages in this example are contained in Download Package > Code > VB_NET > DB_dataURL folder. |
Chart Container Page - Default.aspx |
Default.aspx contains the following code (with code behind page) to render the chart: |
<%@ Page Language="VB" AutoEventWireup="false" CodeFile="Default.aspx.vb" Inherits="DB_dataURL_Default" %> <HTML> <HEAD> <TITLE>FusionCharts - dataURL and Database Example </TITLE> <SCRIPT LANGUAGE="Javascript" SRC="../FusionCharts/FusionCharts.js"></SCRIPT> </HEAD> <body> <form id='form1' name='form1' method='post' runat="server"> <%=GetQuantityChartHtml()%> </form> </body> </HTML> Public Function GetQuantityChartHtml() As String 'In this example, we show how to connect FusionCharts to a database 'using dataURL method. In our other examples, we've used dataXML method 'where the XML is generated in the same page as chart. Here, the XML data 'for the chart would be generated in PieData.aspx. 'To illustrate how to pass additional data as querystring to dataURL, 'we've added an animate property, which will be passed to PieData.aspx. 'PieData.aspx would handle this animate property and then generate the 'XML accordingly. 'For the sake of ease, we've used an Access database which is present in '../DB/FactoryDB.mdb. It just contains two tables, which are linked to each 'other. 'Variable to contain dataURL 'Set DataURL with animation property to 1 'NOTE: It's necessary to encode the dataURL if you've added parameters to it Dim dataURL As String = Server.UrlEncode("PieData.aspx?animate=1") 'Create the chart - Pie 3D Chart with dataURL as strDataURL Return FusionCharts.RenderChart("../FusionCharts/Pie3D.swf", dataURL, "", "FactorySum", "600", "300", False, False) End Function |
In the above code, we're:
|
Creating the data provider page PieData.aspx |
PieData.aspx contains the following code to output XML Data: |
Imports DataConnection |
In the above page:
When you view this page, you'll get the same output as before. |
Create multi-series line chart |
Let's now see how we can create a multi-series chart from database. This is no different from creating the Pie chart we saw above. All you need to do is to build proper XML from the database that you query from your database. Multi-series charts have a different data format from the format of an XML for a single-series chart like pie. Let us see how the code would look for this: |
<%@ Page Language="VB" AutoEventWireup="false" CodeFile="MSCharts.aspx.vb" Inherits="DBExample_MSCharts" %> <HTML> <HEAD> <TITLE>FusionCharts - Database Example </TITLE> <SCRIPT LANGUAGE="Javascript" SRC="../FusionCharts/FusionCharts.js"></SCRIPT> </HEAD> <body> <form id='form1' name='form1' method='post' runat="server"> <asp:Literal ID="Literal1" runat="server"></asp:Literal> </form> </body> </HTML> Code Behind page: Public Function mschartsconnection() As String 'In this example, we show how to connect multi-series FusionCharts to a database. 'For the sake of ease, we've used an Access database which is present in '../App_Data/FactoryDB.mdb. It just contains two tables, which are linked to each 'other. 'xmlData will be used to store the entire XML document generated Dim xmlData As New StringBuilder() 'Generate the chart element xmlData.Append("<chart caption='Factory Output report' subCaption='By Quantity' showBorder='1' formatNumberScale='0' rotatelabels='1' showvalues='0'>") xmlData.Append("<categories>") 'create recordset to get details for the factory id 'create recordset to get details for the datepro Dim factoryQuery As String = "select distinct format(datepro,'dd/mm/yyyy') as dd from factory_output" Dim oRs As New DbConn(factoryQuery) 'Iterate through each record While oRs.ReadData.Read 'Generate the category labels xmlData.Append("<category label='" & oRs.ReadData("dd").ToString() & "'/>") End While oRs.ReadData.Close() 'Close categories element xmlData.Append("</categories>") 'oRs4.ReadData.Close() 'Create recordset to create details for factory names from the master table Dim factoryQuery2 As String = "select * from factory_master" Dim oRs1 As New DbConn(factoryQuery2) 'Iterate through each record While oRs1.ReadData.Read() 'Generate the <dataset seriesname='..'> xmlData.Append("<dataset seriesName='" & oRs1.ReadData("factoryname").ToString() & "'>") 'Create recordset to get the details of the quantity from the factory_output table Dim factoryQuery3 As String = "select quantity from factory_output where factoryid=" + oRs1.ReadData("factoryid").ToString() Dim oRs2 As New DbConn(factoryQuery3) 'Iterate through each record While oRs2.ReadData.Read() 'Generate <set value='..' /> xmlData.Append("<set value='" & oRs2.ReadData("quantity").ToString() & "'/>") End While oRs2.ReadData.Close() 'Close dataset element xmlData.Append("</dataset>") End While oRs1.ReadData.Close() 'Close chart element xmlData.Append("</chart>") 'Create the chart - Multi-Series Line Chart with data from xmlData Return FusionCharts.RenderChart("../FusionCharts/MSLine.swf", "", xmlData.ToString(), "chartid", "600", "400", False, True) End Function Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load Literal1.Text = mschartsconnection() End Sub |
The following actions are taking place in this code:
The chart would look as shown in the image below:
|
Inside DataConnection Namespace |
We have used DataConnection Namespace in the above code and in all subsequent Database examples. Using this class we establish connection to the MS Access database with ADO.NET component. Let's go through the lines of code inside this class: |
Imports Microsoft.VisualBasic Namespace DataConnection ''' <summary> ''' <summary> ' MS Access DataBase Connection - Defined in Web.Config '' SQL Server DataBase Connection - Defined in Web.Config ' Creating Connection string using web.config connection string ' Creating OdbcConnection Object ' Setting Connection String ' Open Connection ' get reader Catch ex As Exception End Sub ' Create a Command object ' Create data reader object using strQuery string End Sub |
What it does:
|