2017-01-11 2 views
0

Я получаю некоторые странные отрицательные значения в своем отчете, которые могут быть из базы данных. Я хочу форматировать поля для отображения нуля, когда значения отрицательны в редакторе выражений. Как это может быть сделано?Как проверить, является ли значение поля BigDecimal отрицательным в JasperReports

+0

Выражение будет выглядеть следующим образом: '$ F {} bigDecimalValue .signum() == -1? «0»: «что-то еще» ' –

+0

@AlexK благодарит, что решил. Но когда я попробовал его по двойному значению, я получил ошибку 'метод signum() не определен для типа Double' – Hilarious404

+0

Хорошо, я получил его' $ V {doubleValue} <0? «0»: «что-то еще» – Hilarious404

ответ

2

Вы должны использовать метод BigDecimal.signum() для проверки знака BigDecimal.

выражение будет:

<textFieldExpression><![CDATA[$P{bigDecimalValue}.signum() == -1 ? "0" : "Not negative big decimal"]]></textFieldExpression> 

Выражение для Двойной проще:

<textFieldExpression><![CDATA[$P{doubleValue} < 0 ? "0" : "Non negative double"]]></textFieldExpression> 

Образец:

<?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="BigDecimal check" pageWidth="595" pageHeight="842" whenNoDataType="AllSectionsNoDetail" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20"> 
    <property name="com.jaspersoft.studio.data.defaultdataadapter" value="One Empty Record"/> 
    <parameter name="doubleValue" class="java.lang.Double" isForPrompting="false"> 
     <defaultValueExpression><![CDATA[1234.567]]></defaultValueExpression> 
    </parameter> 
    <parameter name="bigDecimalValue" class="java.math.BigDecimal" isForPrompting="false"> 
     <defaultValueExpression><![CDATA[new BigDecimal(-9.8)]]></defaultValueExpression> 
    </parameter> 
    <title> 
     <band height="70"> 
      <textField> 
       <reportElement x="10" y="10" width="300" height="15"/> 
        <textFieldExpression><![CDATA[$P{doubleValue} < 0.0 ? "0" : "Non negative double"]]></textFieldExpression> 
      </textField> 
      <textField> 
       <reportElement x="10" y="25" width="300" height="15"/> 
       <textFieldExpression><![CDATA[$P{bigDecimalValue}.signum() == -1 ? "0" : "Not negative big decimal"]]></textFieldExpression> 
      </textField> 
     </band> 
    </title> 
</jasperReport> 

Выходной результат генерируется в Jaspersoft студии будет:

enter image description here

Смежные вопросы