Using FusionCharts ASP Class > Plotting data from a database |
In this section, we'll show you how to use FusionCharts and ASP to plot charts from data contained in a database. We'll create a pie chart to show "Production by Factory" using:
We've used MySQL database here. The database dump is present in Download Package > Code > ASPClass > DB folder. You can, however, use any database with FusionCharts including MS SQL, Oracle, Access 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 > ASPClass > DBExample folder. The MySQL database dump is present in Download Package > Code > ASPClass > DB. |
Database Structure |
Before we code the ASP 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 page that will interact with the database, fetch data and then render a chart. |
Building the ASP Page |
The ASP page for this example is named as BasicDBExample.asp (in DBExample folder). It contains the following code: |
<%@LANGUAGE="VBSCRIPT"%> <% option explicit %> <% 'We've included ../Includes/FusionCharts_Gen.asp, which contains 'FusionCharts ASP Class to help us easily embed charts 'We've also used ../Includes/DBConn.asp to easily connect to a database. %> <!--#include file="../Includes/DBConn.asp"--> <!--#include file="../Includes/FusionCharts_Gen.asp"--> <HTML> <HEAD> <TITLE>FusionCharts V3 - Database Example</TITLE> <% 'You need to include the following JS file, if you intend to embed the chart using JavaScript. 'Embedding using JavaScripts avoids the "Click to Activate..." issue in Internet Explorer 'When you make your own charts, make sure that the path to this JS file is correct. Else, you would get JavaScript errors. %> <SCRIPT LANGUAGE="Javascript" SRC="../../FusionCharts/FusionCharts.js"></SCRIPT> </HEAD> <BODY> <h2><a href="http://www.fusioncharts.com" target="_blank">FusionCharts V3</a> -Database and Drill-Down Example</h2> <% 'In this example, we show how to connect FusionCharts to a database. 'For the sake of ease, we've used an MySQL databases containing two 'tables. dim FC ' Create FusionCharts ASP class object set FC = new FusionCharts ' Set chart type to pie 3D Call FC.setChartType("pie3d") ' Set chart size Call FC.setSize("650","450") ' Set Relative Path of SWF file. Call FC.setSWFPath("../../FusionCharts/") dim strParam ' Define chart attributes strParam="caption=Factory Output report;subCaption=By Quantity;pieSliceDepth=30;numberSuffix= Units;decimals=0" ' Set chart attributes Call FC.setChartParams(strParam) Dim oRs 'Create the recordset to retrieve data Set oRs = Server.CreateObject("ADODB.Recordset") ' Fetch all factory records using SQL Query ' Store chart data values in 'total' column/field and category names in 'FactoryName' dim strQuery strQuery = "select a.FactoryID, b.FactoryName, sum(a.Quantity) as total from Factory_output a, Factory_Master b where a.FactoryId=b.FactoryId group by a.FactoryId,b.FactoryName" Set oRs = oConn.Execute(strQuery) 'Pass the SQL Query result to the FusionCharts ASP Class function 'along with field/column names that are storing chart values and corresponding category names 'to set chart data from database if not oRs.bof then Call FC.addDataFromDatabase(oRs, "total", "FactoryName", "" ,"") end if ' Close Recordset oRs.Close set oRs=Nothing ' Render the chart Call FC.renderChart(false) %> </BODY> </HTML> |
These are the steps that we performed in the above code: |
|
Please go through FusionCharts ASP Class API Reference section to know more about the functions used in the above code. When you now run the code, you'll get an output as under: ![]() |
Converting the example to 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 > ASPClass > DB_dataURL folder. |
Chart Container Page - Default.asp |
Default.asp contains the following code to render the chart: |
<%@LANGUAGE="VBSCRIPT"%> <% 'For the sake of ease, we've used an MySQL databases containing two tables. |
In the above code, we have: |
|
Note: The renderChart() function used in this code is not the same with the one we used in the previous example, though they bear same name. This is FusionCharts ASP chart embedding function; please go through Using with ASP > Basic Examples to know more about it. |
Creating the data provider page PieData.asp |
PieData.asp contains the following code to output XML Data. This code is similar like the Simple DB Example. The only difference is, here we do not render the chart but send the full XML as output stream. |
<%@LANGUAGE="VBSCRIPT"%> |
In the above code: |
|
Please go through FusionCharts ASP Class API Reference section to know more about the functions used in the above code. |
When you view this page, you'll get the same output as before. |