在上篇文章中我们的数据筛选是由RXML文件决定的,即如果我们要改变查询条件的话,要先修改JRXML文件中的SQL语句,再改JAVA文件。这篇文章中我们的数据筛选完全决定于JAVA文件,JRXML文件只负责定义数据格式:
例子同上:有个数据库名字叫TEST,里面有张表存放的是某作物PLANT的编号:PLANT_UUID,和作物的代码号:PLANT_CODE,作为的英文名字:ENGLISH_NAME
一.用ireport生成的JRXML文件:
<?xml version="1.0" encoding="UTF-8" ?>
<!-- Created with iReport - A designer for JasperReports -->
<!DOCTYPE jasperReport PUBLIC "//JasperReports//DTD Report Design//EN" "http://jasperreports.sourceforge.net/dtds/jasperreport.dtd">
<jasperReport
name="JRParameterDemo"
columnCount="1">
<property name="ireport.scriptlethandling" value="2" />
<property name="ireport.encoding" value="UTF-8" />
<import value="java.util.*" />
<import value="net.sf.jasperreports.engine.*" />
<import value="net.sf.jasperreports.engine.data.*" />
<parameter name="uuid" isForPrompting="true" class="java.lang.String">
<defaultValueExpression ><![CDATA[new java.lang.String("uuid")]]></defaultValueExpression>
</parameter>
<field name="PLANT_UUID" class="java.lang.String"/>
<field name="PLANT_CODE" class="java.lang.String"/>
<field name="ENGLISH_NAME" class="java.lang.String"/>
。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
<detail>
<band height="36" isSplitAllowed="true" >
<textField><reportElement key="textField"/>
<textFieldExpression class="java.lang.String"><![CDATA[$F{PLANT_UUID}]]></textFieldExpression>
</textField>
<textField><reportElement key="textField"/>
<textFieldExpression class="java.lang.String"><![CDATA[$F{PLANT_CODE}]]></textFieldExpression>
</textField>
<textField><reportElement key="textField"/>
<textFieldExpression class="java.lang.String"><![CDATA[$F{ENGLISH_NAME}]]></textFieldExpression>
</textField>
</band>
</detail>
。。。。。。。。。。。。。。。。。。。。。。。。
</jasperReport>
为了节省篇幅,我把比如COLUMNHEADER,COLUMNFOOT等部分的内容去掉了,(文中打。。。的部分),读者可以自己用IREPORT生成JRXML文件时自己定义那些部分。
跟上篇文章唯一的区别在于少了<queryString><![CDATA[select * from plant where plant_uuid like $P{uuid}]]></queryString>,因为我们的SQL语句定义在了JAVA文件中。
二. JAVA文件
public class Demo {
public static void main(String[] args) {
Connection conn = null;
ResultSet resultSet = null;
Statement statement = null;
String url = "jdbc:oracle:thin:@IP:PORT:SCHEMA";
String userName = "USERNAME ";
String password = "PASSWORD";
try {
Class.forName("oracle.jdbc.OracleDriver");
} catch (Exception e) {
e.printStackTrace();
}
try {
conn = DriverManager.getConnection(url, userName, password);
} catch (Exception e) {
e.printStackTrace();
}
String sql = "select * from plant where plant_uuid = 'PLANT_UUID_0001'";
try {
statement = conn.createStatement();
resultSet = statement.executeQuery(sql);
} catch (Exception e) {
e.printStackTrace();
}
try {
JasperReport jasperReport = JasperCompileManager
.compileReport("report\\plant.jrxml");
JasperPrint jasperPrint = JasperFillManager.fillReport(
jasperReport, new HashMap(), new JRResultSetDataSource(
resultSet));
JasperExportManager.exportReportToPdfFile(jasperPrint,
"report\\plant.pdf");
} catch (Exception e) {
e.printStackTrace();
}
}
}
这样我们就可以在JAVA文件中根据情况定义SQL语句,JRXML只负责定义数据格式。同样在这种情况下每次都要编译JRXML文件,怎样改进读者可以参考上一篇文章。
分享到:
相关推荐
中国智能交通车路协同的高等级自动驾驶数据交互内容-PDF.7z
Android开发笔记 数据交互--网络图片查看器
Windows-Phone-7-UI设计及人机交互指南-v2.0-中英文对照版.pdf
b2c网站设计中微交互研究-网站设计-设计.pdf
竞品分析(交互)-Profile页.pdf
交互设计-响应式Web设计实践 PDF电子书下载 带书签目录 完整版
CSAE 158-2020 基于车路协同的高等级自动驾驶数据交互内容-2020年版
基于JAVA框架设计模式的学生交互系统设计-2019年教育文档.pdf基于JAVA框架设计模式的学生交互系统设计-2019年教育文档.pdf基于JAVA框架设计模式的学生交互系统设计-2019年教育文档.pdf基于JAVA框架设计模式的学生...
对于前者,人们可以借助键盘、鼠标、操纵杆、数据服装、眼动跟踪器、位置跟踪器、数据手套、压力笔等设备,用手、脚、声音、姿势或身体的动作、眼睛甚至脑电波等向计算机传递信息;对于后者,计算机通过打印机、...
2018海尔家用中央空调自媒体口碑交互方案-89P .pdf
TCSAE 157—2020合作式智能运输系统 车用通信系统应用层及应用数据交互标准-2020年版
变电站调控数据交互规范,QGDW11021-2013变电站调控数据交互规范
数据可视化实战:使用D3设计交互式图表.pdf+源码。
部网络货运信息交互系统代码集 - 2020-09-21.pdf
深圳天软科技-应用专题-第三方交互07:天软平台和PYTHON的交互-2018-03-28
工业互联网数据交互采集.pdf
AxureUX电商产品WEB端交互原型 - 优品汇 v1.0
《用户体验与UI交互设计》教学课件6.3Axure交互基础实例—用户登录.pdf《用户体验与UI交互设计》教学课件6.3Axure交互基础实例—用户登录.pdf《用户体验与UI交互设计》教学课件6.3Axure交互基础实例—用户登录.pdf...