`
boz.lee
  • 浏览: 20438 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

jasreport来交互数据-pdf

阅读更多
在上篇文章中我们的数据筛选是由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文件,怎样改进读者可以参考上一篇文章。 

分享到:
评论

相关推荐

    Vue+ElementUI使用vue-pdf实现预览功能

    在组件内,首先需要定义一些数据属性来控制PDF预览的显示与行为。例如,可以设置一个显示对话框的布尔值,用于控制对话框的显示和隐藏;定义一个存储PDF源地址的属性,用来指定需要预览的PDF文件的路径;以及定义...

    angularjs-pdf-master 在线预览

    3. 实现控制器:在控制器中,你可以调用上述服务的方法来加载PDF文档,并将预览数据绑定到视图。数据绑定是AngularJS的核心特性,使得视图和模型之间的同步变得更加简单。 4. 使用ng-if或ng-show/hide来控制PDF预览...

    基于R 语言数据分析实战

    - PDF 文档 - Office 文档 - 统计分析 - 常见的统计检验 - 回归与相关分析 - 分类数据的分析 - 统计检验的功效 - 数据建模 - 网络数据分析(R 语言社区开发者协作网络) - 文本数据分析 - 时序数据分析...

    医疗信息平台交互规范-HL7 V 3( 行业标准)

    ——第 1 部分:总则 ...——第 7 部分:就诊信息交互服务; ——第 8 部分:医嘱信息交互服务; ——第 9 部分:申请单信息交互服务; ——第 10 部分:预约信息交互服务; ——第 11 部分:结果、状态信息交互服务。

    编码的奥秘-- PDF

    对于程序员来说,理解PDF的内部工作原理有助于开发处理PDF的软件,例如创建、编辑或转换PDF工具。同时,深入学习PDF格式也能帮助优化PDF文件的生成和传输,提高用户体验。通过阅读《编码的奥秘--PDF》,读者可以了解...

    《基于车路协同的高等级自动驾驶应用层数据交互内容》(TCSAE 158-2020).pdf

    总的来说,TCSAE 158-2020标准对于推动中国高等级自动驾驶技术的标准化和商业化进程具有重要意义,它为车路协同环境下的自动驾驶车辆提供了可靠的数据交互框架,有助于构建更加智能、安全的未来交通系统。

    数据可视化实战:使用D3设计交互式图表 pdf版[9MB]1

    第1章写在前面11.1 数据为什么要可视化 11.2 为什么要写代码 21.3 为什么要交互 21.4 为什么要在 Web 上 31.5 这是一本什么书 31.

    部网络货运信息交互系统代码集 - 2020-09-21.pdf

    在具体应用上,货运信息交互系统的代码集可用于数据的存储、查询、统计和分析。通过业务类型代码,可以方便地检索和分析特定业务类型下的运输数据,为业务决策提供依据。车牌颜色代码的应用则可以对特定颜色的车辆...

    bootstrap-table真实交互数据

    如果后台返回的数据包含复杂结构,可以使用`formatter`函数来处理和展示数据。 8. **分页功能**:Bootstrap Table内置了分页功能,可以设置每页显示的行数,以及分页按钮样式。通过配置`pageList`、`pageSize`和`...

    delphi-pdf 控件

    3. **PDF解析和合并**:能够打开和合并多个PDF文件,解析PDF元数据和内容。 4. **版本兼容性**:支持多种PDF版本,确保与不同版本的PDF文件良好兼容。 5. **API友好**:提供清晰的API接口,易于理解和使用,方便进行...

    人机交互技术--原理与应用

    第1章 绪论.ppt ...第3章 交互设备.ppt 第4章 人机交互技术.ppt 第5章 可用性分析与评估.ppt 第6章 人机交互界面表示模型1.ppt 第7章 软件结构与实现.ppt 第8章 Web界面设计.ppt 第9章 移动界面设计.ppt

    《用户体验与UI交互设计》教学课件6.3Axure交互基础实例—用户登录.pdf

    《用户体验与UI交互设计》教学课件6.3Axure交互基础实例—用户登录.pdf《用户体验与UI交互设计》教学课件6.3Axure交互基础实例—用户登录.pdf《用户体验与UI交互设计》教学课件6.3Axure交互基础实例—用户登录.pdf...

    李炎恢JavaScript-PDF

    Adobe Acrobat提供的JavaScript API提供了丰富的函数和方法,用于读取和修改PDF文档的元数据、内容和结构。例如,`thisDoc` 对象提供了对当前文档的访问,`app` 对象则包含与应用程序相关的功能。 4. **表单和字段...

    精通D3.js 交互式数据可视化高级编程_PDF

    《精通D3.js 交互式数据可视化高级编程》是一本深度探讨D3.js库的专著,旨在帮助读者掌握利用D3.js进行高效且富有吸引力的数据可视化的技能。D3.js,全称Data-Driven Documents,是一种强大的JavaScript库,允许...

    CN110740486A数据交互方法终端设备及数据交互系统 .pdf

    CN110740486A数据交互方法终端设备及数据交互系统 .pdf

    05 ADO.NET 2.0 数据交互.pdf

    - **应用程序**:无论是Web应用还是桌面应用,都可以利用ADO.NET技术来进行数据交互。 - **数据库/XML**:ADO.NET不仅可以与数据库进行交互,还支持XML格式的数据交换,这为数据的传输提供了极大的灵活性。 #### 三...

    TCSAE 157—2020合作式智能运输系统 车用通信系统应用层及应用数据交互标准(第二阶段).pdf

    TCSAE 157—2020,即《合作式智能运输系统 车用通信系统应用层及应用数据交互标准(第二阶段)》是由中国汽车工程学会发布的标准文件,旨在推动智能网联汽车产业创新技术的加速发展与广泛应用。 TCSAE 157—2020...

    Ajax实现数据交互技术.pdf

    Ajax实现数据交互技术.pdf Ajax技术是当前Web开发中的一种关键技术,它可以实现异步数据交互,提高Web应用程序的响应速度和用户体验。下面是对Ajax技术的详细说明。 一、什么是Ajax? Ajax是一种技术,它使浏览器...

    PB数据窗口导出PDF并且合并到一个PDF文件中

    标题 "PB数据窗口导出PDF并且合并到一个...总的来说,这个任务涵盖了PB的数据窗口操作、PDF导出、多条件检索、PDF文件合并以及自动化保存等多个技术环节,需要开发者具备扎实的PB编程基础,以及对PDF处理的深入理解。

Global site tag (gtag.js) - Google Analytics