struts+mybatis 根据遍历出的数据库数据画折线图

1.导包:

jcommon-1.0.16.jar
jfreechart-1.0.19.jar

2.写工具类:

public class ChartOne {

//数据采集 (被调用)
  private static CategoryDataset createDataset()
  {
    DefaultCategoryDataset localDefaultCategoryDataset = new DefaultCategoryDataset();
    //第一条折线数据 折线名Series 1
    List<Customer> custlist=CustomerServiceImpl.getInstance().getDayPay();
    for(Customer cust:custlist)
    {
    localDefaultCategoryDataset.addValue(cust.getSum(), "Series 1", cust.getCheck_out());
    }
    return localDefaultCategoryDataset;
  }


  /**
   * 生成折线图(被调用)
   * @param chartTitle 图的标题
   * @param x          横轴标题
   * @param y          纵轴标题
   * @param dataset    数据集
   * @return
   */
  private static JFreeChart createChart(String chartTitle, String x,
       String y, CategoryDataset dataset)
  { 
   // 构建一个chart
   JFreeChart chart = ChartFactory.createLineChart(
           chartTitle,//图的标题
           x,  //x轴标题
           y,  //y轴标题
           dataset,//数据点
           PlotOrientation.VERTICAL,
           true,
           true,
           false);
   //字体清晰
   chart.setTextAntiAlias(false);
   // 设置背景颜色
   chart.setBackgroundPaint(Color.WHITE);

   // 设置图标题的字体
   Font font = new Font("隶书", Font.BOLD, 25);
   chart.getTitle().setFont(font);

   // 设置面板字体
   Font labelFont = new Font("SansSerif", Font.TRUETYPE_FONT, 12);
   // 设置图示的字体
   chart.getLegend().setItemFont(labelFont);

   CategoryPlot categoryplot = (CategoryPlot) chart.getPlot();
   // x轴 // 分类轴网格是否可见
   categoryplot.setDomainGridlinesVisible(true);
   // y轴 //数据轴网格是否可见
   categoryplot.setRangeGridlinesVisible(true);
   categoryplot.setRangeGridlinePaint(Color.WHITE);// 虚线色彩
   categoryplot.setDomainGridlinePaint(Color.WHITE);// 虚线色彩
   categoryplot.setBackgroundPaint(Color.lightGray);// 折线图的背景颜色

   // 设置轴和面板之间的距离
   // categoryplot.setAxisOffset(new RectangleInsets(5D, 5D, 5D, 5D));

   // 横轴 x
   CategoryAxis domainAxis = categoryplot.getDomainAxis();
   domainAxis.setLabelFont(labelFont);// 轴标题
   domainAxis.setTickLabelFont(labelFont);// 轴数值
   // domainAxis.setLabelPaint(Color.BLUE);//轴标题的颜色
   // domainAxis.setTickLabelPaint(Color.BLUE);//轴数值的颜色

   // 横轴 lable 的位置 横轴上的 Lable 45度倾斜 DOWN_45
   domainAxis.setCategoryLabelPositions(CategoryLabelPositions.STANDARD);

   // 设置距离图片左端距离
   domainAxis.setLowerMargin(0.0);
   // 设置距离图片右端距离
   domainAxis.setUpperMargin(0.0);

   // 纵轴 y
   NumberAxis numberaxis = (NumberAxis) categoryplot.getRangeAxis();
   numberaxis.setLabelFont(labelFont);
   numberaxis.setTickLabelFont(labelFont);
   numberaxis.setStandardTickUnits(NumberAxis.createIntegerTickUnits());
   numberaxis.setAutoRangeIncludesZero(true);

   // 获得renderer 注意这里是下嗍造型到lineandshaperenderer!!
   LineAndShapeRenderer lineandshaperenderer = (LineAndShapeRenderer) categoryplot
           .getRenderer();
   lineandshaperenderer.setBaseShapesVisible(true); // series 点(即数据点)可见
   lineandshaperenderer.setBaseLinesVisible(true); // series 点(即数据点)间有连线可见

   // 显示折点数据
   lineandshaperenderer
           .setBaseItemLabelGenerator(new StandardCategoryItemLabelGenerator());
   lineandshaperenderer.setBaseItemLabelsVisible(true);

   return chart;
  }

//获取JFreeChart
  public static JFreeChart createDemoPanel()
  {
 CategoryDataset database = createDataset();
    JFreeChart localJFreeChart = createChart("每日收入","日期","营业额",database);


    return localJFreeChart;
  }
3.web.xml配置

<servlet>
    <servlet-name>DisplayChart</servlet-name>
    <servlet-class>org.jfree.chart.servlet.DisplayChart</servlet-class>
  </servlet>

  <servlet-mapping>
    <servlet-name>DisplayChart</servlet-name>
    <url-pattern>/DisplayChart</url-pattern>
  </servlet-mapping>
4.在action中

private String image;


	
	public String getImage() {
		return image;
	}


	public void setImage(String image) {
		this.image = image;
	}	
public String getDayPayChart() {
	
		ServletActionContext.getRequest().getContextPath();
		// 保存图片 返回图片文件名
		String filename;
		try {
			filename = ServletUtilities.saveChartAsPNG(	ChartOne.createDemoPanel(), 600, 400, null);
			// 获取图片路径(内存中)
			String graphURL = ServletActionContext.getRequest().getContextPath() + "/DisplayChart?filename="+ filename;
			System.out.println(graphURL);
			// 拼接<img src="  " />
			image = "<img src='" + graphURL
					+ "' width=600 height=400 border=0 usemap='#" + filename
					+ "'/>";
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		return "back_daychart";
	}
5.struts.xml配置

<package name="fcf" namespace="/" extends="base">
		
		<action name="pay_*" class="com.hotel.action.CustomerAction" method="{1}">
		   <result name="back_daychart">/frontPages/index.jsp</result>
		</action>
	</package>

6.页面

<!-- tasks -->
			<div class="agile-last-grids">
				
				<div class="col-md-4 agile-last-left agile-last-middle">
					
						<div id="graph8"></div>
						${image }
				</div>
				<div class="clearfix"> </div>
			</div>
		<!-- //tasks -->

7.效果:








  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Spring Boot + MyBatis Plus操作数据库需要进行以下几个步骤: 1.添加依赖 在pom.xml文件中添加以下依赖: ``` <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.2</version> </dependency> ``` 2.配置数据源 在application.properties文件中添加数据源相关的配置信息,如下所示: ``` spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.jdbc.Driver ``` 3.创建实体类 创建与数据库表对应的实体类,并使用注解进行属性与列的映射,如下所示: ``` @Data @NoArgsConstructor @AllArgsConstructor @TableName("user") public class User implements Serializable { @TableId(type = IdType.AUTO) private Long id; private String name; private Integer age; private String email; } ``` 4.创建Mapper接口 创建Mapper接口,并继承MyBatis Plus提供的BaseMapper接口,如下所示: ``` public interface UserMapper extends BaseMapper<User> { } ``` 5.使用Mapper接口操作数据库 在Service或Controller层中使用UserMapper接口进行数据库的操作,如下所示: ``` @Autowired private UserMapper userMapper; public User getUserById(Long id) { return userMapper.selectById(id); } public List<User> getUserList() { return userMapper.selectList(null); } public int addUser(User user) { return userMapper.insert(user); } public int updateUser(User user) { return userMapper.updateById(user); } public int deleteUser(Long id) { return userMapper.deleteById(id); } ``` 以上就是使用Spring Boot + MyBatis Plus操作数据库的基本步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值