2016-05-17 8 views
0

I Bericht mit SQL-Abfrage zu erzeugen versuche:Die Datenquelle der Tabelle ignoriert AND-Klausel in Abfrage mit dem Wert als Parameter übergeben

SELECT brand.id,brand.brand,model.model FROM brand INNER JOIN model ON brand.id=model.id AND model.id=$P{ID} 

Es wird die Benutzereingabe von JavaFX TextField- nehmen. Die Model.id wird durch Single Integer ersetzt, sagen wir 1 und es sollte nur eine Zeile ausgeben! Aber wenn ich diese Parameter an den Bericht JasperReports übergebe, druckt es alle Zeilen, die in der Tabelle verfügbar sind.

Der Java-Code:

@FXML 
public TextField one; 

public void click(ActionEvent event) throws JRException, SQLException, ClassNotFoundException, IllegalAccessException, UnsupportedLookAndFeelException, InstantiationException { 
    String reportSrcFile = "/home/sample/learn.jrxml"; 

    // First, compile jrxml file. 
    JasperReport jasperReport1 = JasperCompileManager.compileReport(reportSrcFile); 

    Connection conn = SqliConnect.getMySQLConnection(); 

    // Parameters for report 
    int two = Integer.parseInt(one.getText()); 
    Map<String, Object> parameters = new HashMap<String, Object>(); 
    parameters.put("ID",one.getText());//The Exact Parameter name is "ID" in the jrxml file. 

    JasperPrint print = JasperFillManager.fillReport(jasperReport1, 
      parameters, conn); 

    JasperViewer jv = new JasperViewer(print); 
    jv.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
    jv.setTitle("Test Report"); 

    jv.setVisible(true); 
} 

Bericht der Vorlage:

<subDataset name="Dataset1" uuid="2691431f-5c6f-403f-94cc-829c17ef1636"> 
    <queryString> 
     <![CDATA[SELECT brand.id,brand.brand,model.model FROM brand INNER JOIN model]]> 
    </queryString> 
    <field name="id" class="java.lang.Integer"/> 
    <field name="brand" class="java.lang.String"/> 
    <field name="model" class="java.lang.String"/> 
</subDataset> 
<parameter name="ID" class="java.lang.String"> 
    <defaultValueExpression><![CDATA[$P{REPORT_CONTEXT}.getId()]]></defaultValueExpression> 
</parameter> 
<queryString> 
    <![CDATA[SELECT brand.id,brand.brand,model.model FROM brand INNER JOIN model ON brand.id=model.id AND model.id=$P{ID}]]> 
</queryString> 
<field name="id" class="java.lang.Integer"/> 
<field name="brand" class="java.lang.String"/> 
<field name="model" class="java.lang.String"/> 
<title> 
    <band height="79" splitType="Stretch"> 
     <textField> 
      <reportElement x="11" y="16" width="100" height="30" uuid="d1485589-a4cf-4ab9-b896-0ef480beced4"/> 
      <textFieldExpression><![CDATA[$P{ID}]]></textFieldExpression> 
     </textField> 
    </band> 
</title> 
<detail> 
    <band height="250" splitType="Stretch"> 
     <componentElement> 
      <reportElement x="160" y="50" width="200" height="200" uuid="e199bd58-8408-4711-85d5-ba76db9691b7"> 
       <property name="com.jaspersoft.studio.layout" value="com.jaspersoft.studio.editor.layout.VerticalRowLayout"/> 
       <property name="com.jaspersoft.studio.table.style.table_header" value="Table_TH"/> 
       <property name="com.jaspersoft.studio.table.style.column_header" value="Table_CH"/> 
       <property name="com.jaspersoft.studio.table.style.detail" value="Table_TD"/> 
      </reportElement> 
      <jr:table xmlns:jr="http://jasperreports.sourceforge.net/jasperreports/components" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports/components http://jasperreports.sourceforge.net/xsd/components.xsd"> 
       <datasetRun subDataset="Dataset1" uuid="7fecdfe6-bed4-433a-97f8-43cc6347c660"> 
        <connectionExpression><![CDATA[$P{REPORT_CONNECTION}]]></connectionExpression> 
       </datasetRun> 
       <jr:column width="66" uuid="9a6b765f-b6d4-4753-909e-dd091b296654"> 
        <jr:columnHeader style="Table_CH" height="30"> 
         <staticText> 
          <reportElement x="0" y="0" width="66" height="30" uuid="7e644d1c-a893-49df-a18a-bf788eb6b92a"/> 
          <text><![CDATA[id]]></text> 
         </staticText> 
        </jr:columnHeader> 
        <jr:columnFooter style="Table_CH" height="30"/> 
        <jr:detailCell style="Table_TD" height="30"> 
         <textField> 
          <reportElement x="0" y="0" width="66" height="30" uuid="848a53bf-2b2e-46df-a7aa-26fc0b897c85"/> 
          <textFieldExpression><![CDATA[$F{id}]]></textFieldExpression> 
         </textField> 
        </jr:detailCell> 
       </jr:column> 
       <jr:column width="66" uuid="514580a5-f09c-43d1-952e-d4769c2e4686"> 
        <jr:columnHeader style="Table_CH" height="30"> 
         <staticText> 
          <reportElement x="0" y="0" width="66" height="30" uuid="c01152e9-1547-472b-946e-92011c02bc94"/> 
          <text><![CDATA[brand]]></text> 
         </staticText> 
        </jr:columnHeader> 
        <jr:columnFooter style="Table_CH" height="30"/> 
        <jr:detailCell style="Table_TD" height="30"> 
         <textField> 
          <reportElement x="0" y="0" width="66" height="30" uuid="98c84ae5-b289-459a-b34b-a9becf43b9ce"/> 
          <textFieldExpression><![CDATA[$F{brand}]]></textFieldExpression> 
         </textField> 
        </jr:detailCell> 
       </jr:column> 
       <jr:column width="66" uuid="5c1d2026-45bc-4ec8-8be4-c444e47d093d"> 
        <jr:columnHeader style="Table_CH" height="30"> 
         <staticText> 
          <reportElement x="0" y="0" width="66" height="30" uuid="81f76de4-a68b-41c3-a2e8-bbaa625b71be"/> 
          <text><![CDATA[model]]></text> 
         </staticText> 
        </jr:columnHeader> 
        <jr:columnFooter style="Table_CH" height="30"/> 
        <jr:detailCell style="Table_TD" height="30"> 
         <textField> 
          <reportElement x="0" y="0" width="66" height="30" uuid="d69c690e-05a4-453a-93ea-9061523975ad"/> 
          <textFieldExpression><![CDATA[$F{model}]]></textFieldExpression> 
         </textField> 
        </jr:detailCell> 
       </jr:column> 
      </jr:table> 
     </componentElement> 
    </band> 
</detail> 

Was ist der richtige Weg, es zu tun?

Update: Ich habe die Parameter für Datenquellen hinzugefügt:

<subDataset name="Dataset1" uuid="2691431f-5c6f-403f-94cc-829c17ef1636"> 
    <property name="com.jaspersoft.studio.data.sql.tables" value=""/> 
    <property name="com.jaspersoft.studio.data.defaultdataadapter" value="Learn"/> 
    <parameter name="ID" class="java.lang.String"/> 
    <queryString> 
     <![CDATA[SELECT brand.id,brand.brand,model.model FROM brand INNER JOIN model ON brand.id=model.id AND model.id=$P{ID}]]> 
    </queryString> 
    <field name="id" class="java.lang.Integer"/> 
    <field name="brand" class="java.lang.String"/> 
    <field name="model" class="java.lang.String"/> 
</subDataset> 

Aber jetzt ist es leer Bericht zu erzeugen.

+0

1) Sie verwenden die Abfrage ohne WHERE-Klausel (Dataset1) 2) Sie sollten die Karte mit Parameter übergeben (* $ P {REPORT_PARAMETER_MAP} *) für die Datenquelle der Tabelle. 3) Es ist besser, die Tabellenkomponente in das Titelband zu verschieben, wenn Sie die Hauptabfrage haben 4) Sie können eine leere Abfrage einstellen, ich denke –

+0

Wie Sie sehen, gibt es viele Probleme mit Ihrem Bericht –

+0

Bitte überprüfen Sie das Update. Ich habe es versucht, aber jetzt erzeugt es einen leeren Bericht. – kodr

Antwort

0

Die Tabellenkomponente in Ihrem Bericht verwendet das Subdataset 'Dataset1', für das kein ID-Parameter definiert ist und der nur eine statische Abfrage enthält. Sie müssen den ID-Parameter auch im Subdataset deklarieren und in der Abfrage verwenden. Ich hoffe, das hilft, Sanda

PS: Bitte beachten Sie die bearbeiteten Rohpaste Daten hier: http://pastebin.com/ZMjn4jtP

+0

Jetzt generieren Sie einen leeren Bericht. Ich habe den Parameter wie folgt hinzugefügt: – kodr

+0

Ich habe den Beitrag aktualisiert. Mache ich etwas falsch? Es generiert leere Seite – kodr

+0

Überprüfen Sie auch Folgendes: Das ID-Feld in Subdataset ist vom Typ java.lang.Integer, während der ID-Parameter vom Typ java.lang.String ist. Der Ausdruck 'model.id = $ P {ID}' in der Abfrage wird in diesem Fall immer false zurückgegeben. Versuchen Sie, Feld und Parameter Integer zu machen. – shertage