怎么从数据库中调出数据并生成动态图表

怎么从数据库中调出数据并生成动态图表,第1张

JSP页面中嵌入动态图表的两种方法 :在JSP页面中插入Applet小程序 ;通过JavaBean动态生成图像。

JSP是一种广泛应用的网页设计技术 ,它是一种HTML和Java脚本混合的编程技术 ,它结合了HTML的静态特性和Java语言的动态能力 ,因此用它进行动态网页设计非常方便。在进行图像处理时 ,一般处理静态非常容易 ,但是 ,在实际应用中常常需要动态地在网页中生成二维的图形

基于JFreeChart开发的一个时序图的绘制。代码如下:

实例中createDataset()方法用于创建数据集合对象。时序图的数据集合与其他数据集合不同,它需要添加一个时间段内的所有数据,通常采用TimeSeries类进行添加。该实例中通过Math类的random()方法进行随机生成。

import javaawt;

import javaawteventActionEvent;

import

javaawteventActionListener;

import javaioBufferedInputStream;

import

javaioDataInputStream;

import javaioFileOutputStream;

import

javaioIOException;

import javanetURL;

import

javanetURLConnection;

import javatextDateFormat;

import

javatextParseException;

import javatextSimpleDateFormat;

import

javautilCalendar;

import javautilDate;

import javautilRandom;

import javaxswingJApplet;

import javaxswingTimer;

import orgjfreechart;

import

orgjfreechartannotationsCategoryTextAnnotation;

import

orgjfreechartaxisCategoryAnchor;

import

orgjfreechartaxisCategoryAxis;

import

orgjfreechartaxisCategoryLabelPositions;

import

orgjfreechartaxisDateAxis;

import

orgjfreechartaxisDateTickUnit;

import

orgjfreechartaxisDateTickUnitType;

import

orgjfreechartaxisValueAxis;

import

orgjfreechartlabelsStandardCategoryItemLabelGenerator;

import

orgjfreechartplotCategoryPlot;

import

orgjfreechartplotPlotOrientation;

import

orgjfreechartplotXYPlot;

import

orgjfreechartrenderercategoryBarRenderer;

import

orgjfreecharttitleTextTitle;

import

orgjfreedatacategoryCategoryDataset;

import

orgjfreedatacategoryIntervalCategoryDataset;

import orgjfreechartaxisNumberAxis;

import

orgjfreedatacategoryDefaultCategoryDataset;

import

orgjfreedataganttTask;

import orgjfreedataganttTaskSeries;

import

orgjfreedataganttTaskSeriesCollection;

import

orgjfreedatatimeDay;

import orgjfreedatatimeSecond;

import

orgjfreedatatimeTimeSeries;

import

orgjfreedatatimeTimeSeriesCollection;

import

orgjfreedataxyXYDataset;

public class shixutu extends JApplet {

//PLOT_FONT是一静态的字体常量对象,使用此对象可以避免反复用到的字体对象被多次创建

private static final Font PLOT_FONT = new Font("黑体", FontITALIC ,

18);

JFreeChart chart;

//创建数据动态更新的监听

class DataGenerator extends Timer

implements ActionListener {

private static final long serialVersionUID =

3977867288743720504L;

String

equID;

//设备ID号

int

totalTask;

//任务数

String[][]

strTask;

//任务情况

public void

actionPerformed(ActionEvent actionevent) {

addTotalObservation();

} DataGenerator()

{

super(1000,

null);

addActionListener(this);

Systemoutprintln("super");

}

}

//将更新的数据添加到chart中

private void addTotalObservation()

{

Systemoutprintln("addTotalObservation");

//设置新的数据集

chartgetXYPlot()setDataset(createDataset());

//通知Jfreechart

数据发生了改变,重新绘制柱状图

if

(chart != null)

{

chartfireChartChanged();

}

}

private static void

processChart(JFreeChart chart)

{

//设置标题字体

chartgetTitle()setFont(new Font("隶书", FontBOLD,

26));

//设置背景色

chartsetBackgroundPaint(new

Color(252,175,134));

XYPlot plot = chartgetXYPlot();

//获取图表的绘制属性

plotsetDomainGridlinesVisible(false);

//设置网格不显示

//获取时间轴对象

DateAxis dateAxis = (DateAxis)

plotgetDomainAxis();

dateAxissetLabelFont(PLOT_FONT);

//设置时间轴字体

//设置时间轴标尺值字体

dateAxissetTickLabelFont(new

Font("宋体",FontPLAIN,12));

dateAxissetLowerMargin(00);

//设置时间轴上显示的最小值

//获取数据轴对象

ValueAxis valueAxis =

plotgetRangeAxis();

valueAxissetLabelFont(PLOT_FONT);

//设置数据字体

DateFormat format = new SimpleDateFormat("mm分ss秒");

//创建日期格式对象

//创建DateTickUnit对象

DateTickUnit dtu = new

DateTickUnit(DateTickUnitTypeSECOND,30,format);

dateAxissetTickUnit(dtu);

//设置日期轴的日期标签 } //将结果输出在文件中

private static

void writeChartAsImage(JFreeChart chart)

{

FileOutputStream fos_jpg =

null;

try

{

fos_jpg = new

FileOutputStream("D:\\test\\shixutujpg");

ChartUtilitieswriteChartAsJPEG(fos_jpg, 1, chart, 400, 300,

null);

} catch (Exception e)

{

eprintStackTrace();

} finally

{

try

{

fos_jpgclose();

} catch (Exception e)

{

}

}

}

//创建数据集合对象

public static XYDataset createDataset()

{

//实例化TimeSeries对象

TimeSeries timeseries = new

TimeSeries("Data");

Second second = new Second();

//实例化Day

double d =

50D;

//添加一年365天的数据

for (int i = 0; i < 500; i++)

{

d = d + (Mathrandom() - 05) 10;

//创建随机数据

timeseriessecond(day, d);

//向数据集合中添加数据

second = (Second)

secondnext();

}

TimeSeriesCollection timeSeriesCollection =

new

TimeSeriesCollection(timeseries);

//返回数据集合对象

return timeSeriesCollection; } //Applet程序初始化

public void init()

{

// 1

得到数据

XYDataset dataset =

createDataset();

// 2

构造chart

chart =

ChartFactorycreateTimeSeriesChart(

"时序图示范", //

图表标题

"时间", //

目录轴的显示标签--横轴

"数值", //

数值轴的显示标签--纵轴

dataset, //

数据集

false,

false, //

是否生成工具

false //

是否生成URL链接

);

// 3

处理chart中文显示问题

processChart(chart);

// 4

chart输出

//writeChartAsImage(chart);

// 5 chart

以swing形式输出

//6使用applet输出

ChartPanel chartPanel = new

ChartPanel(chart);

chartPanelsetPreferredSize(new

javaawtDimension(800,500));

getContentPane()add(chartPanel); (new

DataGenerator())start();

}

public void

paint(Graphics g)

{

if

(chart != null)

{

chartdraw((Graphics2D) g,

getBounds());

}

}

public void destroy() {

}

}

简单写下代码,思路是使用数据库链表填充,先看代码吧:

//数据库怎么 *** 作读取数据我就不写了,假如现在有了dataset对象ds,在查数据表的时候就把顺序排列好

for(int i=0;i<dsTables[0]RowsCount;i++)

{

treeNodesAdd(dsTables[0]Rows[i]["列名"]ToString());

}

如果要加入子节点,那就加完父节点再查找子节点,挨个加进去:

//建立个ds返回对象,以父节点作为参数

for(int i=0;i<dsTables[0]RowsCount;i++)

{

treeNodesAdd(dsTables[0]Rows[i]["列名"]ToString());

}

foreach(TreeNodes td in treeNodes)

{

for(int j=0;j<tdText)Tables[0]RowsCount;i++)

{

tdAdd(dss(tdText)Tables[0]Rows[j]["列名"]ToString());

}

}

因为你提的问题,编译环境上很不明确所以我做了以下假设。

系统环境linux

编译器GCC

数据库mysql

(编译还需要安装mysql的接口-dev这个库)

这样的情况下只需要包含

然后做以下 *** 作

MYSQLmysql_init(MYSQLmysql);//初始化mysql

MYSQLmysql_real_connect(MYSQLmysql,constcharhost,constcharuser,constcharpasswd,constchardb,unsignedintport,constcharunix_socket,unsignedlongclient_flag);//连接数据库具体参数含义请查MYSQLAPI文档

intmysql_query(MYSQLmysql,constcharstmt_str);//执行sql语句如果想添加表的话stmt_str赋值为"CREATETABLEXXXX"就行了

以上就是关于怎么从数据库中调出数据并生成动态图表全部的内容,包括:怎么从数据库中调出数据并生成动态图表、c# treeview 动态 数据库、请问如何用C语言动态为数据库添加一个表等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9777603.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存