ireport5.6.0分组显示
一,ireport中分组
二,java调用实现分组
一,ireport中分组:
1,新建模板文件,纸张随意,名称随意,路径随意
2,连接要分组的数据源
3,添加测试表和数据
CREATE TABLE yananTest (
departId INT,
departName VARCHAR (20),
stuName VARCHAR (20)
)GO INSERT INTO yananTest VALUES(1,'开发部','张亚南'),(1,'开发部','随意'),(2,'实施部','实施1'),(2,'实施部','实施2'),(2,'实施部','实施3'),(3,'销售部','销售1')
GO
4编写sql查询数据
勾选自动提取字段或点击读取字段,能出来蓝色行表示查询无误。点击ok,确定后在左侧Fields字段自动出现蓝色行的字段
5,右击报表点击add report group
groupname随意,选择departId,departId是要分组的依据
下一步中的 group header footer根据自己实际情况,此处为了展示都要
确定后detail1前后会加上分组header和footer
6拖动departName到header栏,stuName到detail1栏,footer随便加一条横线
如果组件面板不显示的话在窗口中点击组件面板即可
拖动后为了美观好看可以调整header、footer、detail1栏的边界线调整下高度
大功告成,点击预览
二,java调用实现分组
我的第一思路是,删除sql语句在Fields中添加字段,java中传参,行不通,因为调用的时候,Fields是接收不到java的传参的。我的第二思路是在Parameters中建立这几个字段,然后传参,仍然行不通,因为分组只能是字段(有待进一步研究),传参是集合。我的第三想法是添加dataset,进行分组,呜呜,初接触我还不会,等以后确定了再补上。最后千辛万苦终于找到方法
sql语句不变,java传数据库连接
方法如下:
将上述report1.jrxml编译后将生成的report1.jasper文件copy到项目指定目录下,我的是目录是i根目录下的report
实现如下代码
@RequestMapping("/test")
@ResponseBody
public void test(HttpServletRequest req,HttpServletResponse res) throws Exception{
Map<String, Object> map = new HashMap<String, Object>();
String realPath = ClassUtils.getDefaultClassLoader().getResource("").getPath();//项目根目录。该处是springboot方式
ServletContext context = req.getSession().getServletContext();
WebApplicationContext wac = WebApplicationContextUtils.getRequiredWebApplicationContext(context);
DataSource dbSource = (DataSource) wac.getBean("dataSource"); // 配置文件里的beanid
Connection conn = dbSource.getConnection();
byte[] bytes = JasperRunManager.runReportToPdf(realPath + "ireport/report1.jasper", map, conn);
res.setContentType("application/pdf");
res.setContentLength(bytes.length);
ServletOutputStream out = res.getOutputStream();
out.write(bytes, 0, bytes.length);
out.flush();
out.close();
}
启动项目访问即可出现步骤一6中的pdf页面部分。如果中文不显示,参考之前的文章@ireport初接触
至于java中使用ireport详细说明,参考下一篇文章
ireport5.6.0分组显示的更多相关文章
- Linq DataTable Group By 分组显示人员明细
实现功能: 多个字段分组源码样例: 原始数据: 分组后的输出结果: 源代码: public static void PrintPersons() { //准备数据 DataTable dt ...
- iReport5.6.0 linechart 制作方法
iReport 官网和文档上关于chart设计以饼图和JDBC源作为样例.但很多其它的情况下因为报表中的数据须要首先加工处理,因此很多其它的是从JavaBeans set datasource从获取数 ...
- 重新想象 Windows 8 Store Apps (12) - 控件之 GridView 特性: 拖动项, 项尺寸可变, 分组显示
原文:重新想象 Windows 8 Store Apps (12) - 控件之 GridView 特性: 拖动项, 项尺寸可变, 分组显示 [源码下载] 重新想象 Windows 8 Store Ap ...
- wpf CollectionViewSource与ListBox的折叠、分组显示,及输入关键字 Filter的筛选
在wpf中虽然ObservableCollection<T>作为ListBox的Itemsource,很好,很强大!但是CollectionViewSource与ListBox才是天作之合 ...
- MySQL数据中分级分组显示数据
前面已经有了SqlServer数据分级分组显示数据了.今天又来做一个MySQL数据库中的分级分组显示,SqlServer中用到了递归,这里为了简单就直接把根的数据显示为0 ,而不用递归了. 在MySQ ...
- 小程序开发笔记(八)—Js数组按日期分组显示数据
数据分组展示有两种方式,一种是后端直接传入分组格式的Json数据,另一种是我们在前端自己转换格式,这里我们在前端处理转换按日期分组的数据格式 1.例如后端返回数据格式为: [{createtime:' ...
- vc6.0如何显示行号以及出现版本不兼容问题
有时编译时,提示某某行有错,但是要定位到某一行的话,如果在编辑页面能够将行号显示出来,查找也就更方便了,下面我来介绍一下让VC6.0显示行号的方法. 工具/原料 VC6.0.显示行号的插件 方 ...
- Group GridView:用于.Net的分组显示的GridView
我的项目需要一个可以分组显示的GridView,我不会写,上网找了一圈,最终在国外的网站上找到的这个,比较符合我的要求,但它的分页得重写,它写了能分页,但我发现它的分页功能事实上并没有实现,也不知道是 ...
- excel 单元格0 不显示的最佳方法
excel单元格设自定义格式, 条件:可以单元格内容判断后再设置格式.条件格式化只限于使用三个条件,其中两个条件是明确的,另个是“所有的其他”.条件要放到方括号中.必须进行简单的比较.例如这个条件:单 ...
随机推荐
- python应用-21根火柴游戏
""" 21跟火柴 """ from random import randint def main(): total=21 while to ...
- The Best Open Source Game Engine: In Search Of Perfection
https://www.greatsoftline.com/the-best-open-source-game-engine-in-search-of-perfection/ The game eng ...
- idea 将java导出为可执行jar及导入jar依赖
使用maven可以很好的帮助我们进行依赖的管理,也可以使用maven的jar包打包插件构建出可运行的jar.那针对不是用maven进行管理的普通java项目,可以通过以下方式导出可执行的jar包以及导 ...
- (尚034)Vue_案例_数据存储优化(代码优化!!!)
最好能将上述代码抽取成一个模块(读json数据+写json数据) 1.在src下新建文件夹util(util文件夹用于放入工具的模块) 2.*使用localStorage存储数据的工具模块* 一个模块 ...
- JavaScript原始类型转换和进制转换
1.JavaScript转换包括:强制转换和基本转换 如: var str = 'A',num=10,nu=null,t=true,und=undefined,x; //注意:定义的x未被初始化:默 ...
- 【11NOIP提高组】选择客栈(信息学奥赛一本通 1546)(洛谷 1311)
题目描述 丽江河边有nn家很有特色的客栈,客栈按照其位置顺序从 11到nn编号.每家客栈都按照某一种色调进行装饰(总共 kk 种,用整数 00 ~k-1k−1 表示),且每家客栈都设有一家咖啡店,每家 ...
- mysql 全连接和 oracle 全连接查询、区别
oracle的全连接查询可以直接用full on,但是在mysql中没有full join,mysql使用union实现全连接. oracle的全连接 select * from a full joi ...
- Swagger-BootStrap-UI生成的接口文档如何加Basic校验
首先我们来看看swagger-bootstrap-ui的效果,如图所示: 看起来是不是比Swagger要大气的多. 回到重点上,为什么要给接口文档加密呢? 只对内开放,不对外开放,防止被第三方非公司人 ...
- Mysql中联合索引的最左匹配原则(百度)
创建联合索引时列的选择原则 经常用的列优先(最左匹配原则) 离散度高的列优先(离散度高原则) 宽度小的列优先(最少空间原则) 在Mysql建立多列索引(联合索引)有最左前缀的原则,即最左优先.如果我们 ...
- 【Gamma】 Scrum Meeting 1
github 本此会议项目由PM召开,召开时间为5月26日晚上10点 召开时长20分钟 任务表格 姓名 当前任务 下阶段任务 袁勤 后端插入判断题 后端插入简答题 彭一夫 填空题答题前端 判断题答题前 ...