如何定义和读取空XML字段?

时间:2017-09-27 13:27:47

标签: xml jasper-reports jaspersoft-studio

我正在使用Jaspersoft工作室创建标签。我正在使用XML文件和XMLDataAdapter。这是我的XML文件的示例

<records>
  <record>
    <metadatas>
        <title>first title</title>
        <description>descriptions</description>
        <keywords />
        <!-- ... -->
    </metadatas>
  </record>
</records>

这里的问题是我想访问关键字字段,可以在某些情况下设置或不设置,但是当我尝试读取数据适配器中的字段时,它们不显示。

是否有可以更改的配置或某些东西我可以编译我的jasperreport。

1 个答案:

答案 0 :(得分:0)

没有特殊设置,您只是没有定义相对于XPath查询的字段

在您的示例中,您可能希望循环记录,以便您的XPath查询

<queryString language="XPath">
    <![CDATA[/records/record]]>
</queryString>

要定义指向keywords的字段,请使用fieldDescription

<field name="keywords" class="java.lang.String">
    <fieldDescription><![CDATA[metadatas/keywords]]></fieldDescription>
</field>
  

名称是任意的,类是java中值的表示,fieldDescription是与queryString相关的节点的相对路径

JasperSoft Studio

在JasperSoft Studio中,这是通过先defining your data adapter,然后右键单击报告节点,然后选择&#34;数据集和查询&#34;来实现的。在对话框中选择数据适配器和XPath,然后编写XPath查询并单击要添加为字段的字段

Dataset and Query

完整的jrxml示例

<?xml version="1.0" encoding="UTF-8"?>
<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="XMLTest" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="b487729d-4510-4485-b838-19c491042208">
    <property name="com.jaspersoft.studio.data.defaultdataadapter" value="XMLTest"/>
    <queryString language="XPath">
        <![CDATA[/records/record]]>
    </queryString>
    <field name="title" class="java.lang.String">
        <fieldDescription><![CDATA[metadatas/title]]></fieldDescription>
    </field>
    <field name="description" class="java.lang.String">
        <fieldDescription><![CDATA[metadatas/description]]></fieldDescription>
    </field>
    <field name="keywords" class="java.lang.String">
        <fieldDescription><![CDATA[metadatas/keywords]]></fieldDescription>
    </field>
    <columnHeader>
        <band height="20" splitType="Stretch">
            <property name="com.jaspersoft.studio.unit.height" value="pixel"/>
            <staticText>
                <reportElement x="0" y="0" width="170" height="20" uuid="3ce3004b-8324-4f57-ba9f-77cdffc711da"/>
                <textElement verticalAlignment="Middle">
                    <font isBold="true"/>
                </textElement>
                <text><![CDATA[title]]></text>
            </staticText>
            <staticText>
                <reportElement x="170" y="0" width="170" height="20" uuid="6ee7c571-ecdc-45cc-b11d-600099121301"/>
                <textElement verticalAlignment="Middle">
                    <font isBold="true"/>
                </textElement>
                <text><![CDATA[description]]></text>
            </staticText>
            <staticText>
                <reportElement x="340" y="0" width="210" height="20" uuid="111fa52f-bc0b-4698-8ba9-a7af03988254"/>
                <textElement verticalAlignment="Middle">
                    <font isBold="true"/>
                </textElement>
                <text><![CDATA[keywords]]></text>
            </staticText>
        </band>
    </columnHeader>
    <detail>
        <band height="20" splitType="Stretch">
            <property name="com.jaspersoft.studio.unit.height" value="pixel"/>
            <textField>
                <reportElement x="0" y="0" width="170" height="20" uuid="444010e8-18ce-4594-a1b1-ca3d120b091d"/>
                <textElement verticalAlignment="Middle">
                    <font isBold="false"/>
                </textElement>
                <textFieldExpression><![CDATA[$F{title}]]></textFieldExpression>
            </textField>
            <textField>
                <reportElement x="170" y="0" width="170" height="20" uuid="9a27a707-c5df-4905-ac21-e42b21c1d77c"/>
                <textElement verticalAlignment="Middle">
                    <font isBold="false"/>
                </textElement>
                <textFieldExpression><![CDATA[$F{description}]]></textFieldExpression>
            </textField>
            <textField>
                <reportElement x="340" y="0" width="210" height="20" uuid="1621de6d-7200-49aa-a0d4-56f64fec1b91"/>
                <textElement verticalAlignment="Middle">
                    <font isBold="false"/>
                </textElement>
                <textFieldExpression><![CDATA[$F{keywords}]]></textFieldExpression>
            </textField>
        </band>
    </detail>
</jasperReport>

示例数据源

<records>
  <record>
    <metadatas>
        <title>first title</title>
        <description>descriptions</description>
        <keywords />
    </metadatas>
  </record>
  <record>
    <metadatas>
        <title>second title</title>
        <description>descriptions 2</description>
        <keywords>test, hello</keywords>
    </metadatas>
  </record>
</records><records>
  <record>
    <metadatas>
        <title>first title</title>
        <description>descriptions</description>
        <keywords />
    </metadatas>
  </record>
  <record>
    <metadatas>
        <title>second title</title>
        <description>descriptions 2</description>
        <keywords>test, hello</keywords>
    </metadatas>
  </record>
</records>

输出

Result

正如您所看到的那样,对于没有值的节点,它会显示null,如果您想在相对isBlankWhenNull="true"

上设置textField空文本