niceyoo
博客园
首页
管理
码云
淘宝店
耳机推荐
随笔 - 343
文章 - 0
评论 - 238
阅读 - 152万
ureport2报表详细使用
一、报表简介
UReport2是一款基于架构在Spring之上纯Java的高性能报表引擎,通过迭代单元格可以实现任意复杂的中国式报表。 在UReport2中,提供了全新的基于网页的报表设计器,可以在Chrome、Firefox 等各种主流浏览器运行 (不支持IE)。 使用UReport2,打开浏览器即可完成各种复杂报表的设计制作。
二、主体功能
UReport2支持创建数据源、添加数据集,并对数据集进行函数、表达式处理;(参考【数据处理】)
UReport2支持对数据集形成可视化报表,包括饼状图、柱状图、曲线图等等(参考【图表展示】)
三、优缺点阐述
优点:
(1)开源、免费,集成即可使用;
(2)轻量级、易集成,工程中添加依赖即可进行集成使用;
(3)支持多函数处理,包括常用函数(sum、count、max、min、avg)、数学函数、字符串函数、日期函数等等;
(4)支持多种图表展示,包括饼状图、柱状图、曲线图、圆环图、雷达图、散点图等等;
缺点:
(1)工程在使用过程中经常出现空指针或者其他报错;
(2)UReport2部分功能不可用,包括导出及多条件表达式SQL查询等;
(3)支持数据源类型少,当前支持:mysql、SQLserver、oracle、db2等
四、集成及配置
UReport2的设计器是基于网页的,配置好一个项目,也就完成了报表设计器的安装。因为 UReport2是一款纯Java的报表引擎,所以它支持现在流行的所有类型J2EE项目,下面将具体介绍基于maven的SpringBoot工程如何集成UReport2 ,并基于当前工程进行一系列的数据处理及报表展示。
4.1 创建springboot工程
1、如果当前本地无springboot工程,提供下载地址:https://github.com/niceyoo/springboot-demo
2、基于已下载的springBoot工程,修改index.html文件内的外部js文件路径,将../修改为../../(原始路径不正确);
4.2 添加依赖
1、在springBoot工程的pom文件dependencies中添加依赖;
<dependency>
<groupId>com.bstek.ureport</groupId>
<artifactId>ureport2-console</artifactId>
<version>2.3.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>com.bstek.ureport</groupId>
<artifactId>ureport2-core</artifactId>
<version>2.3.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.7</version>
</dependency>
2、在springBoot工程的pom文件添加repositories;
<repositories>
<repository>
<id>snapshots</id>
<url>https://oss.sonatype.org/content/repositories/snapshots/</url>
</repository>
<repository>
<id>sonatype</id>
<url>https://oss.sonatype.org/content/groups/public/</url>
</repository>
</repositories>
3、基于当前工程,创建webapp/WEB-INF目录,工程【main】目录右键【Directory】》输入【webapp】,基于webapp,继续新建directory》【WEB-INF】;
4.3 创建web.xml文件并配置
1、基于已新建【webapp】》【WEB-INF】目录,添加web.xml文件,点击【file】》【Project Structure】》【Facets】》【web】,新增web.xml文件及web resources directory;
说明:
E:\company\idea\IdeaProjects\springboot-demo-master\src\main:为当前我工程的路径
E:\company\idea\IdeaProjects\springboot-demo-master\src\main\webapp\WEB-INF\web.xml(第5步)
E:\company\idea\IdeaProjects\springboot-demo-master\src\main\webapp (第7步)
2、基于步骤6新增的web.xml文件,添加listener及context-param、servlet、servlet-mapping;
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:ureport-console-context.xml</param-value>
</context-param>
<servlet>
<servlet-name>ureportServlet</servlet-name>
<servlet-class>com.bstek.ureport.console.UReportServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ureportServlet</servlet-name>
<url-pattern>/ureport/*</url-pattern>
</servlet-mapping>
4.4 创建UreportConfig 文件
1、基于工程启动文件的父节点,创建子文件夹ureport》config,并创建UreportConfig 文件;
package com.song.configuration.ureport.config;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.ImportResource;
import com.bstek.ureport.console.UReportServlet;
/**
* Ureport2 配置类
* @author qiaolin
* @version 2018年5月9日
*/
@ImportResource("classpath:ureport-console-context.xml")
@EnableAutoConfiguration
@Configuration
@ComponentScan(basePackages = "com.song.configuration")
public class UreportConfig {
@Bean
public ServletRegistrationBean buildUreportServlet(){
return new ServletRegistrationBean(new UReportServlet(), "/ureport/*");
}
}
2、在配置途中,当缺少包时,需要根据提示自行添加、下载依赖,配置完成,点击resources目录,修改application.properties文件中关于mysql的配置,换成可用库(因为当前springboot工程是以一张user表为例的,所以当前连接的数据库中需要包含user表,囊括id、name、password字段),工程启动的端口号,默认是8080,此处已修改为18090;
#server
server.port=18090
server.tomcat.uri-encoding=utf-8
#MySQL(当前仅为示例)
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/jeesite?characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=123456
4.5 启动工程
1、当上述均配置完成,进入到启动文件Entry,右键点击【Run Entry】启动工程;
4.6 访问工程
工程成功启动,访问地址为: http://localhost:18090/ureport/designer
五、报表基础配置
5.1 工具栏
1)顶栏:针对报表:报表预览、保存报表、打开报表、导入excel、报表配置、查询表单设计器;
针对单元格:重做(下一步)、撤销(上一步)、合并/拆分单元格、上下对齐、表格有无边框、斜线表头;
针对数据:字体样式、字体大小、是否加粗、斜体、下划线、背景色、字体颜色、图片、二维码、图表
图片:
选择左侧单元格,在右侧对应属性区域,输入图片路径,默认支持以classpath:开头位于classpath下的图片文件,或以/开头位于WEB应用根目录下或某目录下的图片文件;
比如"/WEB-INF/static/images/test.jpg"
2)左栏:单元格栏,可针对指定单元格进行单元格样式及数据的设置,鼠标右键可设置单元格;
标题行:
在报表计算后分页时只会出现在第一页第一行的行,如果定义了多个行为标题行类型,那么这些行将在报表运行后分页输出时第一页最前面插入标题行。需要注意的是,我们在报表中可以将位于任意位置的行定义成标题行,但报表计算分页输出时,总会将这些定义为标题行的行放在报表的第一页最前端显示;
重复表头:
与标题行不同的是,定义为重复表头行的行,在报表计算分页输出时会将定义成重复表头行的行放在每一页的前端进行显示。如果当前报表中定义的有标题行,那么对于第一页,标题前将位于最上面,其下才是重复表头行定义的行;
重复表尾:
与重复表头行类型,它也会在报表计算分页输出时放在每一页中显示,只是它会在每一页的最下端显示;
总结行:
与标题行对应,总结行会出现在报表计算后分页输出时最后一页的最下端显示。如果当前报表中定义了重复表尾行,那么在报表计算后分页输出的最后一页中总结后将位于重复表尾行下方显示。
3)右栏:单元格属性栏及数据源配置,可针对(2)中指定单元格,进行链接、类型(文本、表达式、数据集、图片、斜表头、二维码、条码、图表)、及对应类型下参数设置;
备注:
A、不同类型单元格,配置参数不一致,按界面要求输入参数即可;
B、链接:为单元格设置链接的后缀,比如URL配置为:/user/index,目标窗口:新窗口,那么在【预览报表】时,点击该单元格,将跳转到http://localhost:18090/user/index界面
5.2 报表存储
上述工程启动完成后,在springboot-demo-master\src\main\webapp\WEB-INF下自动生成了一个ureportfiles文件夹,用于存放报表文件,这个目录一般是默认的,当然也可以支持修改, 此处以默认路径进行介绍,如果需要修改,请自行参考报表存储目录配置。
设计界面,点击保存图标,试保存一个报表文件,如下图所示:
5.3 自定义报表存储器
UReport2默认提供的名为“服务器文件系统”的报表存储机制,
可查看源码 com.bstek.ureport.provider.report.ReportProvider :源码, 实现了ReportProvider接口后,只需要将实现类配置到Spring中,让其成为一个标准的Spring Bean,这样UReport2就会检测到它而将其加载。ureport2支持自定义报表存储器, 通过实现ReportProvider接口 开发一个新的报表存储器将报表文件存储到数据库、FTP等。
5.4 数据源配置
数据源配置是ureport2中的重点模块,因为后续数据处理、计算、报表展示都是基于数据源中的数据集进行操作的。
ureport2支持 三种类型的报表数据源: 直接连接数据库,Spring Bean以及通过实现com.bstek.ureport.definition.datasource.BuildinDatasource接口提供的内置数据源。
1、直连数据源:比较简单
实现方式:
1)在工程pom文件中添加驱动依赖(当前是这种)
2)在WEB-INF下建立lib文件夹,将驱动jar文件放置在lib中;
3)界面点击
说明:此处数据作为示例,具体以用户当前存在的数据库为准。
数据源名称:test
连接用户名:qingqing
连接密码:qingqing
驱动名称:com.mysql.jdbc.Driver
连接URL:jdbc:mysql://localhost:3306/mysql?allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8&useSSL=false
2、Spring Bean数据源
可以选择Spring上下文中定义好的一个Bean来作为数据源 ,点击叶子
图标, 在弹出的窗口中输入数据源名称及要采用的Bean的ID (必须真实存在)即可,保存完成,即可基于当前数据源右键,添加数据集,输入 数据集名称、对应的方法名以及返回对象类型 ,具体可参考配置Spring Bean数据源
3、内置数据源:
这种类型的数据源,要示我们实现BuildinDatasource接口,同时将BuildinDatasource接口实现类配置到Spring即可;
1)BuildinDatasource源码:
package com.bstek.ureport.definition.datasource;
import java.sql.Connection;
/**
* @author Jacky.gao
* @since 2017年2月9日
*/
public interface BuildinDatasource {
/**
* @return 返回数据源名称
*/
String name();
/**
* @return 返回当前采用数据源的一个连接
*/
Connection getConnection();
}
2)BuildinDatasource接口实现类UreportDataSource:
package com.bstek.ureport.definition.datasource;
import java.sql.Connection;
import java.sql.SQLException;
import javax.sql.DataSource;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import com.bstek.ureport.definition.datasource.BuildinDatasource;
@Component
public class UreportDataSource implements BuildinDatasource {
private Logger log = LoggerFactory.getLogger(UreportDataSource.class);
private static final String NAME = "UreportDataSource";
@Autowired
private DataSource dataSource;
/**
* 数据源名称
*/
@Override
public String name() {
return NAME;
}
/**
* 获取连接
*/
@Override
public Connection getConnection() {
try {
return dataSource.getConnection();
} catch (SQLException e) {
log.error("Ureport数据源,获取连接失败!");
e.printStackTrace();
}
return null;
}
}
3)将实现类配置到spring(ureport-console-context.xml):
添加如下:
<bean id="ureport.UreportDataSource" class="com.bstek.ureport.definition.datasource.UreportDataSource"></bean>
图标,将出现UreportDataSource内置数据源,如下图所示:
六、添加数据集
6.1 配置数据源
1)设计报表界面,选择右侧数据源,点击
图标,输入相关数据源相关连接信息,:说明:此处数据作为示例,具体以用户当前存在的数据库为准。
数据源名称:test
连接用户名:root
连接密码:123456
驱动名称:com.mysql.jdbc.Driver
连接URL:jdbc:mysql://localhost:3306/jeesite?allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8&useSSL=false
2)信息输入完成,点击【测试连接】,提示“连接测试成功”;
6.2 添加数据集
1)选择已添加的数据源“test”,右键点击【添加数据集】;
2)进入数据源添加界面,左侧展示test数据源内的所有table,右侧展示SQL输入区及参数栏;
3)基于已存在的table,添加数据集【当前jeesite数据库里已事先添加了一张transfer_task表,表内有项目的实际数据,后续将基于这张表进行基本的功能演示及介绍】,双击transfer_task表,右侧将自动导入SQL
【支持复杂SQL,可自行在SQL输入框中输入:比如多表查询、left join等等,输入完成可预览数据】;
备注:
SQL输入区同样支持表达式语法,表达式以${}进行包裹
表达式模式:
param是固定表达,表示参数。当job_type为空或为null时,全查询,否则查询指定类型的transfer_task记录,主要用于后续处理数据,在设计表单时可针对当前参数设置查询条件(参考下图):
${
if(param("job_type")=='' || param("job_type")== null){
return "select * from transfer_task"
}else{
return "select * from transfer_task where job_type=:job_type"
}
}
4)预览数据,这块界面排版及布局不够友好,但支持鼠标左右移动进行数据查看,也相当于是横向滚动条;
5)数据集添加完成,可针对数据集进行后续处理;
6)数据源与数据集均支持增、删、改操作,鼠标选中右键即可操作,此处不做过多介绍;
7)值得一提的是,可针对已添加的数据集,进行删除字段操作,删除后,后续使用此数据集时,都不再展示该字段;
6.3 加载数据集至表格
1)点击左侧表格A1,选择右侧数据源栏已添加的数据集“transfer_task”,双击所需要的字段(此处以worker_name为例)同理,依次为B1、C1、D1单元格添加数据集reader_number、write_number、status字段;
表格宽度可调整,也可通过鼠标直接拉长
2)对当前表格添加边框,便于预览表格时层次分明;
3)基于(2),在字段上方添加一行,依次选中A1、B1、C1、D1,在右侧文本内容中输入:worker_name、reader_number、write_number、status,并添加边框;
4)点击【预览报表】》【预览】,预览报表数据;
5)报表展示当前四个字段数据,数据以默认的分组方式进行展示;
6)报表支持分页预览(分页预览模式下,数据将更清晰的进行展示),分页预览如下:
7)报表预览界面,支持对报表导出为PDF、在线打印、导出为Word、excel、分页导出excel、分页分sheet导出为excel(功能不是很好用,当有合并列时,在线预览及导出布局会有问题,部分时候数据会有丢失情况出现),此处不做过多介绍,可自行体验。
七、数据处理
1)回到报表设计界面,查看表格具体参数配置,当前所有字段默认聚合方式均为:分组;
聚合方式用途列表(select)对数据不作处理完整展示分组(group)将数据相同的作为一组进行展示自定义分组对数据自定义条件并进行分组,比如reader_number大于1000汇总(sum)针对数值型字段数据,统计该字段值相加的和,比如transfer_task记录中reader_number的和统计数量(count)针对数值型字段数据,统计所有记录中记录的条数,比如139条transfer_task记录最大值(max)针对数值型字段数据,展示当前记录中该字段值最大的那条记录最小值(min)针对数值型字段数据,展示当前记录中该字段值最小的那条记录平均值(avg)针对数值型字段数据,展示当前记录中该字段的平均值
参数用途数据集下拉列表,展示数据源处已添加的数据集属性在选择数据集之后,下拉列表展示该数据集下所有属性字段聚合方式聚合方式包括列表、分组、自定义、汇总、统计、最大值、最小值、平均值等,参考上面表格排序方式针对数据集数据,可进行正序和倒序排列数据展开方式向下、向右、不展示,可依据需要进行选择行高可自行依据数据真实高度进行设置换行计算开启,或关闭,默认关闭格式化可针对数值型数据及日期型数据进行格式化,比如#.00(保留两位小数),yyyy/mm/dd(年月日)等补充空白行打开,关闭,默认关闭,打开情况下将设置数据行倍数,当总行数不是数据行倍数时自动补充空白行条件属性可配置条件项,对当前值/指定属性/表达式进行条件配置,符合条件的数据行/单元格可进行属性配置
7.1 新增列并求和
1)新增一列并统计读写总数量,鼠标右键【插入列(后)】,新增列count,并在E2单元格输入表达式sum(B2,C2),统计每行数据读写之和,最终合并第三行(必须合并),编辑属性输入表达式,sum(E2),统计所有记录的读写和;
2)预览报表数据,当读数量超过28的数据均已添加背景色,并且数据已加粗表示,最后列表新增count列,数据为每行记录读写之和,最后一行是合计数据,累计读写之和,通过在数据库中查询SQL验证数据正确;
7.2 数据过滤
1)回到报表设计界面,进行部分数据过滤,以reader_number字段为例,过滤掉读数目小于28条的记录(也就是保留reader_number>28的数据都保留),选择B2单元格,编辑右侧属性,点击【过滤条件】,新增一条
2)预览报表数据,列表仅展示读数目大于28的记录;
7.3 数据映射
1)回到报表设计界面,对部分数据进行映射,此处以status字段为例,将status=1的映射为成功,status=2的映射为异常,status=3的映射为运行中,status=4的映射为已终止;
选择D2单元格,右侧点击【数据映射】,点击【+】,添加映射;
2)预报报表数据,C2列数据成功被映射,如下图所示:
7.4 时间格式化
1)新增一个报表,还是以transfer_task为例;添加字段id、reader_number、write_number、create_date,当某一字段值是时间属性,需要对其进行格式化时,可配置格式化参数(格式化之前可先预览数据看看时间数据是什么样的),
支持yyyy/MM/dd、yyyy/MM、yyyy-MM、yyyy、yyyy-MM-dd HH:mm:ss、yyyy年MM月dd日:HH:mm:ss、yyyy-MM-dd、yyyy年MM月dd日;
2)设置完成,预览报表,将会自动将时间格式化为规定的格式。
7.5 单元极引用
在报表当中,大多数的计算都是针对单元格或与单元格有关,因为报表中单元格多数都与数据绑定,而数据往往又是多条,所以计算后的报表一个单元格会产生多个,这样对于单元格的引用就变的比较复杂。在UReport2中,引用的目标单元格是相对当前单元格来进行计算的,引用方法就是直接在表达式里书写单元格名称,比如引用A1单元格,就直接写A1即可 。
目标格获取原则
UReport2中单元格表达式在取目标格值时,优先考虑的是目标格是否与其位于同一行或列
如果是则取与其位于同一行或列的目标单元格,如果不是,则取与当前单元格有共同父格的所有目标单元格,如果他们有共同的上父格或共同的左父格,那么就取共同上父格与共同左格交集部分的目标单元格;如果他们没有共同的父格,那么就取迭代后所有的目标单元格。
多个值的输出
在UReport2中,如果取到值超过一个,输出时多个值间以“,”分隔,类似于:“1,2,3,4”这种。
针对无共同左父格和共同上父格的单元格,我们可以修改左父格及上父格以确保可以进行计算。
更改父格实现单元格取值
在之前的视频教程中,在介绍报表计算模型时,我们多次利用更改当前单元格的上父格或左父格使得当前单元格与目标格处于某个特定的父格下,其原理就来自于此。
w3cschool教程上有很多具体的例子,可以参见:单元格引入
7.6单元格坐标
为了实现更为复杂的单元格引用,UReport2引用了单元格坐标的概念。单元格坐标,也是相对于当前单元格来进行计算的,同样遵循上面的介绍的优先取同行、同列或共同父格的原则,一个标准的单元格坐标格式如下:
单元格坐标格式
单元格名称[Li:li,Li-1:li-1,…;Ti:ti,Ti-1:ti-1…]{条件...}
L表示左父格,l表示左父格展示后的序号,序号为负值,表示向上位移;T表示上父格,t表示上父格展开后的序号,序号为负值,表示相对于当前单元格向上位移,正值则表示向下位移,如果只有左父格,那么直接写L部分即可;如果只是上父格,那么前面需要加上“;”号,然后写T部分,后面的大括号中是条件部分,多个条件之间用and/or连接,表示对通过坐标取到的单元格进行条件过滤(如果取到多个单元格的话),条件部分是可选的,相关示例如下:
单元格坐标示例说明C1[A1:2,B1:1]在找C1时先找单元格A1展开后的第2格;再找第二个A1下的B1单元格展开后的第一个单元格,然后再找这个B1单元格对应的C1单元格C2[A1:2,B1:2;C1:3]在找C2时,先找A1单元格展开后的第二格,再找第二个A1单元格下B2单元格展开后的第二格,再根据第二个展开的B2单元格找其下名为C2单元格的左子格;然后再找到C1单元格展开后的第三格,再看其下的C2单元格,取C2单元格的交集C2[A1:2,B2:2]{C2>1000}表示取A2单元格展开后的第二格,再取其下B2单元格展开后第二格,再取B2下所有的C2单元格,最后再对取到的C2单元格进行条件过滤,只取出C2单元格值大于1000的所有C2单元格。C2[A1:2,B2:2]{C2>1000 and C2<10000}表示取A2单元格展开后的第二格,再取其下B2单元格展开后第二格,再取B2下所有的C2单元格,最后再对取到的C2单元格进行条件过滤,只取出C2单元格值大于1000且小于10000的所有C2单元格的值。
引用所有单元格
如果我们需要引用所有单元格时,那么只需要在单元格名称后跟”[]“即可,如A1[],表达引用所有A1单元格,而不管当前引用格所在位置,同时在引用所有单元格时,还可以后跟条件,以对引用格做进一步条件限制,如A1[]{@>1000 and @<10000},表示要引用所有的A1单元格,但要求引用的A1单元格值要大于1000同时小于10000,这里的@符号是2.2.3及以后版本新增加的一个表达式符号,专门用于取条件循环中当前循环对象。
关于$B2
在UReport2当中,在单元格名称前加$符号,表示取相对于目标单元格的单元格的值,多用在条件比较当中,比如上面的C2[A2:-1]{B2==$B2},这里的$B2就是指取到的C2单元格对应的B2单元格的值。
关于&标记的使用
在使用“&单元格名称”来标记目标单元格展开后的序号时,除上需要注意上面描述的内容外,还需要注意,取序号将以他们共同的父格为基准,如果他们有共同的父格,那么将以这个父格里目标单元格的数量来进行序号编排,这在之前视频教程介绍报表计算模型中,实现明细型主从报表,对从表数据进行编号时就有体现
具体使用可参见:单元极坐标。
7.7 count函数
count函数是对给定的表达式在计算后对象数量进行统计。
示例说明count(B2,C2)统计相对当前所在单元格,目标B2单元格以及C2单元格加在一起的数量count(B2)统计相对当前所在单元格,目标B2单元格数量count(B2{reader_number>20},C2{write_number>28})统计相对当前所在单元格,目标B2单元格绑定对象的reader_number属性大于20的B2单元格以及C2单元格绑定对象的write_number属性大于28的单元格数量count(C2{write_number>20})统计相对当前所在单元格,目标C2单元格绑定对象的write_number属性大于20的C2单元格数量
如图:
预览报表:
7.8 sum函数
sum函数是对给定的表达式在计算后值进行累加,sum函数要求各个表达式计算后的值必须是数字,否则将产生错误。
示例说明sum(B2)相对当前单元格,取到所有B2单元格值进行累加sum(C2{write_number>28})相对当前单元格,取到所有绑定对象属性write_number大于28的C2单元格值进行累加sum(B2,C2)相对当前单元格,取到所有B2和C2单元格的值进行累加sum(B2{reader_number>28},C2{write_number>28})相对当前单元格,取到所有绑定对象属性reader_number大于28的B2单元格值以及绑定对象属性write_number大于28的C2单元格的值进行累加
如图:
预览报表数据:
7.9 avg函数
avg函数是对给定的表达式在计算后值求平均值,avg函数要求各个表达式计算后的值必须是数字,否则将产生错误,求平均数比较简单,此处不进行过多介绍,可参见函数。
示例说明avg(B2)相对当前单元格,求B2单元格的平均值avg(C2{write_number>28})相对当前单元格,取到绑定对象属性write_number大于28的C2单元格值的平均值avg(B2,C2)相对当前单元格,求B2和C2单元格的平均值avg(B2{reader_number>28},C2{write_number>28})相对当前单元格,取到所有绑定对象属性reader_number大于28的B2单元格值以及绑定对象属性write_number大于28的C2单元格的值进行求平均值
7.10 max函数
max函数是对给定的表达式在计算后值求其中的最大值,max函数要求各个表达式计算后的值必须是数字,否则将产生错误。
示例说明max(B2)相对当前单元格,求B2单元格的最大值max(C2{age>28})相对当前单元格,取到绑定对象属性age大于28的C2单元格值的最大值max(B2,C2)相对当前单元格,求B2和C2单元格的最大值max(B2{reader_number>28},C2{write_number>28})相对当前单元格,取到所有绑定对象属性reader_number大于28的B2单元格值以及绑定对象属性write_number大于28的C2单元格的值进行求最大值
7.11min函数
min函数是对给定的表达式在计算后值求其中的最小值,min函数要求各个表达式计算后的值必须是数字,否则将产生错误。
示例说明min(B2)相对当前单元格,求B2单元格的最小值min(C2{age>28})相对当前单元格,取到绑定对象属性age大于28的B2单元格值的最小值min(B2,C2)相对当前单元格,求B2和C2单元格的最小值min(B2{reader_number>28},C2{write_number>28})相对当前单元格,取到所有绑定对象属性reader_number大于28的B2单元格值以及绑定对象属性write_number大于28的C2单元格的值进行求最小值
7.12 row函数(取行号)
取当前单元格所在行的行号,这个函数比较简单,它没有参数。
示例说明row()取当前单元格所在行的行号
7.13 column函数(取列号)
取当前单元格所在列的列号,这个函数比较简单,它没有参数。
示例说明column()取当前单元格所在列的列号
7.14 order函数(排序)
order函数需要两个参数,第一个为要进行排序的对象表达式,第二个是一个布尔值,用来设置排序方式,true正序,false为倒序。
示例说明order(C2,false)相对当前单元格,取到所有C2单元格值,对这些值进行倒序排序,返回排序好的结果集合order(C2{write_number>28},true)相对当前单元格,取到与C2单元格绑定的对象属性write_number值大于28的所有C2单元格值,对这些值进行正序排序,返回排序好的结果集合
7.15 list函数(罗列数据)
取到表达式中定义所有数据,并以集合形式返回。
示例说明list(C2)相对当前单元格,取到所有C2单元格值以集合形式返回list(B2,C2{write_number>28})相对当前单元格,取到所有B2单元格值及C2单元格中write_number属性大于28的所有C2单元格值以集合形式返回
如图:
预览报表数据:
7.16 param函数
可参考【添加数据集】章节的表达式模式SQL。
param函数用来获取外部传入的参数,它需要一个参数,用于指定要获取的参数名称。
示例说明param("job_type")获取外部传入的名为job_type的参数值param(C2)相对于当前单元格,取到C2单元格的值,如果有多个C2单元格则么第一个,然后以这个C2单元格值作为参数名称,获取外部对应的参数值。
${
if(param("job_type")=='' || param("job_type")== null){
return "select * from transfer_task"
}else{
return "select * from transfer_task where job_type=:job_type"
}
}
7.17 formatdate函数(格式化日期)
参考【数据处理】》【时间格式化】章节。
对给定的日期参数进行格式化,它至少需要一个参数,第一个参数是要格式化的日期类型的对象,第二个参数是可选的,用于定义格式化采用的模式,如不指定则用默认的:yyyy-MM-dd HH:mm:ss来进行格式化。
示例说明formatdate(D2)取到D2单元格值,这个值必须是日期类型,然后按yyyy-MM-dd HH:mm:ss来进行格式化成字符串输出formatdate(D2,"yyyyMMdd")取到D2单元格值,这个值必须是日期类型,然后按yyyyMMdd来进行格式化成字符串输出
7.18 formatnumber函数(格式化数字)
对给定的参数进行格式化,它至少需要一个参数,第一个参数是要格式化的数字对象,要保证这个参数值取到后可以转换成日期,否则将发生错误;第二个参数是可选的,用于定义数字格式化采用的模式,如不定义,则采用默认的#来进行格式化。
示例说明formatnumber(B2)取到B2单元格值,这个值必须可以转换成数字,然后按#来进行格式化成字符串输出formatnumber(B2,"#,###.00")取到B2单元格值,这个值必须可以转换成数字,然后按#,###.00来进行格式化成字符串输出
支持格式化格式包括:#.##、#.00 、 ##.##% 、 ##,##.##、 ##0.0E0、 ¥##,###.##、 $##,###.##
7.19 非常用函数
分页函数:
所谓分页相关函数,是指这些函数是在分页的时候进行计算,比如计算当前页有多少条记录、当前页某个单元格值累加后是多少、平均值是多少、最大值是多少等等。
分页相关函数使用
一般来说,分页相关函数多用在行类型为“重复表头”或“重复表尾”的行中的单元格里。
同时,需要注意的是,分页相关函数只会在分页预览时显示,这点需要注意。
pcount函数、psum函数、pmax函数、pmin函数、page函数、pages函数等
pages函数的使用范围
pages函数目前仅能在页眉页脚中使用
数学函数:
abs函数(求绝对值)、ceil函数(最小值)、floor函数(最大值)、chn函数(数字转中文)、rmb函数(数字转换为大写的人民币金额)、cos函数(余弦)、sin函数(正弦)、tan函数(正切)、exp函数(方法用于返回自然数底数e的参数次方)、log10函数(返回以10为底的对数值)、log函数(自然对数)、median函数(中位数)、mode函数(众数)、vara函数(方差)、stdevp函数(标准差)、pow函数(返回第一个参数的第二个参数次方)、random函数(随机数)、round函数(四舍五入)、sqrt函数(平方根)
chn函数使用注意事项
chn函数转换数字即可是整数,也可是小数,如果是小数支持后面最多两位小数,如果实际小数过多,chn函数会先进行四舍五入,然后再进行转换。
rmb函数使用注意事项
rmb函数转换数字即可是整数,也可是小数,如果是小数支持后面最多两位小数,如果实际小数过多,rmb函数会先进行四舍五入,然后再进行转换。
日期函数:
date函数(日期)、day函数(天)、month函数(月)、week函数(星期)、year函数(年)
字符串函数:
indexOf函数(位置)、length函数(长度)、lower函数(转小写)、upper函数(转大写)、replace函数(替换字符串)、substring函数(子字符串)、trim函数(去空格)、json函数(解析JSON字符串)
对JSON字符串的要求
json函数在解析JSON字符串时,要求必须是标准的JSON字符串,比如下面这样的:
{"name":"superman","age":32,"company":{"name":"bstek","address":"SHANGHAI CHINA"}}
也就是key属性也需要用“”包裹的,如果是下面这种类型的JSON字符串就解析时就会产生错误:
{name:"superman",age:32,company:{name:"bstek",address:"SHANGHAI CHINA"}}
八、查询表单设计
查询表单设计主要是针对于使用表达式类型的SQL而言的,具体使用如下:
1)保存当前报表,点击左上角保存按钮;
2)浏览器地址输入: http://localhost:18090/ureport/designer ,开始新增一个全新报表;
3)添加jdbc数据源,参考【配置数据源】章节;
4)基于数据源,添加新的表达式数据集,参考【添加数据集】表达式模式;
${
if(param("job_type")=='' || param("job_type")== null){
return "select * from transfer_task"
}else{
return "select * from transfer_task where job_type=:job_type"
}
}
5)基于数据集,设计报表,添加边框等:
按钮,进入查询表单设计器界面;
7)选择三列布局,并依次在三列中,加入单选列表、提交按钮、重置按钮;
8)点击【属性】框,对单选列表进行设置:
绑定参数:job_type,即添加数据集的SQL中的参数;
标题位置:左边;
标题:输入“类型”;
选项:稽核作业、流处理作业(多余选项删除掉)
9)提交和重置按钮,将标题修改一下:查询、重置即可,按钮风格改为:基本
10)关闭设计窗口,预览报表,查看数据:
11)选择类型:稽核作业,进行查询,展示对应查询条件的数据记录;
九、图表展示
UReport2中支持10种类型的图表,分别是:饼状图、圆环图、曲线图、柱状图、水平柱状图、面积图、雷达图、极坐标图、散点图以及气泡图,点击工具栏上的
插入图表的图标,在弹出的菜单中选择目标图表类型,即可完成图表的添加工作。
选中图表所在单元格,即可在属性面板中配置图表的相关属性。在UReport2中,图表的属性有三类,分别是与数据集绑定的属性、配置XY轴的相关属性以及配置图例标题之类的属性。
对于饼状图、圆环图、雷达图、极坐标图图表来说,由于它们没有XY轴,所以在属性面板中看不到XY轴配置标签页。
在绑定数据集配置的的标签页中,可以用来配置图表要表现的具体数据,在UReport2中图表绑定的数据都来自数据源,所以在配置图表之前,我们需要准备好需要用图表展示的具体数据的数据集。
对于饼状图、圆环图、曲线图、柱状图、水平柱状图、面积图、雷达图、极坐标图几种图表来说,它们要展示数据结构一样。
操作:
1)保存当前“查询表单设计”图表;
2)浏览器输入地址: http://localhost:18090/ureport/designer ,新建一个空图表并进行保存为饼状图;
3)新增jdbc数据源并添加数据集,数据集内的SQL:select * from transfer_task;
4)左侧单元格区域合并单元格,点击
图标;
5)点击
插入饼状图;
9.1 饼状图
配置:
(1)点击单元格属性;
(2)数据集tab,选中数据集“饼状图”;
(3)选择分类属性:worker_name;
(4)选择值属性:reader_number;
(5)值属性选择属性值,属性选择del_flag;
(6)聚合方式选择:汇总(统计不同del_flag状态,不同worker内的读数量总和);
聚合方式:
A、汇总:统计不同状态,不同worker内的读数量总和;
B、罗列数据:展示第一条记录的数据值,无参考意义;
C、统计数量:统计不同状态、不同worker内的task任务条数;
D、最大值:统计不同状态,不同worker内的读条数最高的并展示;
E、最小值:统计不同状态,不同worker内的读条数最小的并展示;
F、平均值:统计不同状态,不同worker内的读条数平均值并展示
选项:
A、标题:支持配置图标的标题并进行指定位置展示,当前默认:否;
B、图例展示:支持配置图例,即是否展示数据集tab中配置的分类属性,当前默认:是;
C、数据标签:支持配置数据标签,配置完成将在图表默认展示数据,即值属性,当前默认:否。
预览报表:
9.2 圆环图
(1)单元格区域,在饼状图下方添加8行
(2)选择新增的8行单元格,点击
图标合并单元格,并点击
插入圆环图;
(3)选择圆环图单元格,配置单元格属性:
1、点击单元格属性;
2、数据集tab,选中数据集“饼状图”;
3、选择分类属性:worker_name;
4、选择值属性:reader_number;
5、值属性选择属性值,属性选择del_flag;
6、聚合方式选择:汇总(统计不同del_flag状态,不同worker内的读数量总和);
预览圆环图:
9.3 曲线图
(1)单元格区域,在圆环图下方添加8行;
(2)选择新增的8行单元格,点击
图标合并单元格,并点击
插入曲线图;
(3)选择曲线图单元格,配置单元格属性:
1、点击单元格属性;
2、数据集tab,选中数据集“饼状图”;
3、选择分类属性:worker_name;
4、选择值属性:reader_number;
5、值属性选择属性值,属性选择del_flag;
6、聚合方式选择:汇总(统计不同del_flag状态,不同worker内的读数量总和);
轴配置:
X轴配置、Y轴配置:
(1)标题旋转角度:默认0;
(2)显示轴标题:默认否;
(3)轴标题:默认空
预览曲线图:
9.4 柱状图
(1)单元格区域,在饼状图右侧添加4列;
(2)选择新增的4列单元格,点击
图标合并单元格,并点击
插入柱状图;
(3)选择柱状图单元格,配置单元格属性:
1、点击单元格属性;
2、数据集tab,选中数据集“饼状图”;
3、选择分类属性:worker_name;
4、选择值属性:reader_number;
5、值属性选择属性值,属性选择del_flag;
6、聚合方式选择:汇总(统计不同del_flag状态,不同worker内的读数量总和);
预览柱状图:
9.5 水平柱状图
(1)选择柱状图下方的8行单元格,点击
图标合并单元格,并点击
插入水平柱状图;
(2)选择水平柱状图单元格,配置单元格属性:
1、点击单元格属性;
2、数据集tab,选中数据集“饼状图”;
3、选择分类属性:worker_name;
4、选择值属性:reader_number;
5、值属性选择属性值,属性选择del_flag;
6、聚合方式选择:汇总(统计不同del_flag状态,不同worker内的读数量总和);
预览水平柱状图:
9.6 面积图
(1)选择水平柱状图下方的单元格,点击
图标合并单元格,并点击
插入面积图;
(2)选择面积图单元格,配置单元格属性:
1、点击单元格属性;
2、数据集tab,选中数据集“饼状图”;
3、选择分类属性:worker_name;
4、选择值属性:reader_number;
5、值属性选择属性值,属性选择del_flag;
6、聚合方式选择:汇总(统计不同del_flag状态,不同worker内的读数量总和);
预览面积图:
9.7 雷达图
(1)单元格区域,在柱状图右侧添加4列;
(2)选择新增的4列单元格,点击
图标合并单元格,并点击
插入雷达图;
(3)选择雷达图单元格,配置单元格属性:
1、点击单元格属性;
2、数据集tab,选中数据集“饼状图”;
3、选择分类属性:worker_name;
4、选择值属性:reader_number;
5、值属性选择属性值,属性选择del_flag;
6、聚合方式选择:汇总(统计不同del_flag状态,不同worker内的读数量总和);
预览雷达图:
9.8 极坐标图
(1)选择雷达图下方的8行单元格,点击
图标合并单元格,并点击
插入极坐标图;
(2)选择极坐标图单元格,配置单元格属性:
1、点击单元格属性;
2、数据集tab,选中数据集“饼状图”;
3、选择分类属性:worker_name;
4、选择值属性:reader_number;
5、值属性选择属性值,属性选择del_flag;
6、聚合方式选择:汇总(统计不同del_flag状态,不同worker内的读数量总和);
预览极坐标图:
9.9 散点图
(1)选择极坐标图下方的单元格,点击
图标合并单元格,并点击
插入散点图;
(2)选择散点图单元格,配置单元格属性:
1、点击单元格属性;
2、数据集tab,选中数据集“饼状图”;
3、选择分类属性:status;
4、X值属性:write_number;
5、Y值属性:reader_number
预览散点图:
十、报表打印、导出
ureport2支持打印报表,不过存在bug,数据会显示不全,导出为Word文档同样存在问题,数据不全且当有合并单元格时数据会混乱展示;
建议方式:
预览数据界面,点击【在线打印】将数据缩放保存为pdf模式,再进行打印;
数据支持导出为excel、支持分页导出excel、支持分页分sheet导出为excel;
十一、ureport2不支持自动发送邮件
十二、权限控制
ureport2本身不支持权限控制,但是码云上有用户将 renren-security采用SpringBoot2.0、MyBatis、Shiro框架,开发的一套权限系统 ,集成了ureport2,但是目前还不成熟,还存在问题。
参考地址: https://gitee.com/zkool/renren-security-ureport2
分类: javaWeb
标签: ureport2, ureport2报表
关注我
收藏该文
« 上一篇: 华强北AirPods耳机购买指南~买前必看系列
» 下一篇: 影视电影视频微信小程序源码-激励视频+banner广告+视频广告+插屏广告
posted @ 2021-01-22 00:28 niceyoo 阅读(30097) 评论(5) 编辑 收藏 举报
刷新评论刷新页面返回顶部
登录后才能查看或发表评论,立即 登录 或者 逛逛 博客园首页
未来,我们一起成长。
昵称: niceyoo
园龄: 5年9个月
粉丝: 489
关注: 10
搜索
随笔分类
Android(6)
Docker(15)
ElasticStack(8)
Flutter(31)
javaWeb(56)
java基础(21)
jeecg(16)
JVM(6)
Linux(5)
Netty(2)
RabbitMQ(10)
Redis(8)
Spring(14)
SpringBoot(24)
SpringMVC(7)
SSH框架(1)
SSM框架(2)
uni-app(6)
Vue(8)
工具相关(69)
面试相关(14)
数据库(8)
随笔感悟(34)
微信&支付宝(17)
基友链接
涂涂影院-在线影院
华强北耳机推荐链接
华强北耳机个人站点
阅读排行榜
1. Java序列化与反序列化(35269)
2. IDEA社区版(Community)和付费版(UItimate)的区别(34934)
3. 基于Docker的Redis集群搭建(34446)
4. SSM(Spring+SpringMVC+Mybatis)框架环境搭建(整合步骤)(一)(33233)
5. 支付宝支付—沙箱环境使用(32072)
6. ureport2报表详细使用(30097)
7. 无需付费,教你IDEA社区版中开发Web项目(SpringBoot\Tomcat)(28812)
8. AB1562_UT软件分辨真假洛达1562A,洛达1562a怎么鉴别?(26869)
9. uni-app第三方登陆-微信(23954)
10. uniapp中使用微信jssdk(22245)
11. CentOS7防火墙端口开放(18709)
12. spring-boot-starter-parent(17640)
13. JPA分页查询与条件分页查询(16785)
14. JDK(JDK8,JDK11)高速下载(16026)
15. Failed to load driver class com.mysql.jdbc.Driver from HikariConfig class classloader sun.misc.Launcher$AppClassLoader@18b4aac2(15476)
16. Vue中import引入模块路径时的@符号(15032)
17. Java异常分类及处理(14757)
18. SpringSecurity 整合 JWT(14003)
19. Windows下RocketMQ的启动步骤(13806)
20. 洛达AirPods鉴别检测工具AB153x_UT,支持1562a 1562f(13695)
推荐排行榜
1. JDK(JDK8,JDK11)高速下载(11)
2. Java序列化与反序列化(9)
3. Spring Boot 项目瘦身指南,瘦到不可思议!129M->1.3M(8)
4. Vue中import引入模块路径时的@符号(8)
5. new String("123") 创建了几个对象?(6)
6. 一年工作经验的大专生程序员(java后台—实习篇)(6)
7. Redis分布式锁—Redisson+RLock可重入锁实现篇(5)
8. 基于Docker的Redis集群搭建(5)
9. 毕业一年的大专生程序员工作总结(java后台)(5)
10. spring-boot-starter-parent(5)
11. 基于Docker搭建Redis集群(主从集群)(4)
12. 无需付费,教你IDEA社区版中开发Web项目(SpringBoot\Tomcat)(4)
13. IDEA社区版(Community)和付费版(UItimate)的区别(4)
14. 网站三级分销数据库如何设计,简单案例(4)
15. Docker开启远程安全访问(4)
16. 支付宝支付—沙箱环境使用(4)
17. 博客园文章方块背景格式(4)
18. Java异常分类及处理(4)
19. ureport2报表详细使用(3)
20. 毕业两年的大专生程序员工作总结(java后端)(3)
Copyright © 2022 niceyoo
Powered by .NET 7.0 on Kubernetes
用户评论
这《我的港口2》玩起来还真是挺费脑子的,每次建仓库都要算时间,考验数学能力啊。
有8位网友表示赞同!
刚入手这个游戏,界面有点复杂,得好好研究一下才知道操作。
有15位网友表示赞同!
玩了几天,《我的港口2》,感觉升级港口设备好刺激,就像自己真的在当老板一样。
有8位网友表示赞同!
太有意思了,港口里那些货物种类繁多,每一种货物都能给我带来不同的体验。
有19位网友表示赞同!
新版本更新后感觉更好玩了,交通系统更智能了。
有6位网友表示赞同!
我女儿也跟着我一起玩这个游戏,一起管理港口,亲子活动太棒啦!
有9位网友表示赞同!
港口里的船只设计得非常有型,看着都过瘾。
有20位网友表示赞同!
感觉这个游戏的模拟精度很高,各种细节都考虑到了。
有11位网友表示赞同!
有些任务挺有挑战性的,《我的港口2》真的让人欲罢不能。
有17位网友表示赞同!
物流管理挺考验玩家统筹能力的,我有时候还得用个小本子记下数据呢。
有11位网友表示赞同!