सबरपोर्ट बनाएं

सब्रेपोर्ट्स जैस्पररिपोर्ट्स की अच्छी विशेषताओं में से एक है। यह सुविधा किसी अन्य रिपोर्ट के भीतर एक रिपोर्ट को शामिल करने की अनुमति देती है, अर्थात एक रिपोर्ट दूसरे की सब -पोर्ट हो सकती है। सबप्रोर्ट हमें रिपोर्ट डिज़ाइन को सरल रखने में मदद करते हैं, क्योंकि हम कई सरल रिपोर्ट बना सकते हैं और उन्हें मास्टर रिपोर्ट में इनकैप्सुलेट कर सकते हैं। सबरपोर्ट्स को सामान्य रिपोर्टों की तरह ही संकलित और भरा जाता है। किसी भी रिपोर्ट टेम्प्लेट का उपयोग सब -पोर्ट के रूप में किया जा सकता है जब किसी अन्य रिपोर्ट टेम्प्लेट में शामिल किया जाता है, बिना कुछ बदले (रिपोर्ट टेम्पलेट के)।

सबरपोर्ट सामान्य रिपोर्ट टेम्पलेट्स की तरह हैं। वे वास्तव में net.sf.jasperreports.engine.JasperReport ऑब्जेक्ट हैं, जो net.sf.jasperreports.engine.design.JasperDesign ऑब्जेक्ट को संकलित करने के बाद प्राप्त होते हैं ।

<सबरपोर्ट> तत्व

मास्टर रिपोर्ट में सब्रेपोर्ट पेश करते समय एक <सबरपोर्ट> तत्व का उपयोग किया जाता है। यहां <सबरपोर्ट> JRXML तत्व में उप-तत्वों की सूची दी गई है।

  • <reportElement>

  • <पैरामीटर्सपाइज़रप्रेशन> - इसका उपयोग एक नक्शा पास करने के लिए किया जाता है जिसमें रिपोर्ट पैरामीटर सबरपोर्ट के लिए होता है। नक्शा आमतौर पर मास्टर रिपोर्ट में एक पैरामीटर से प्राप्त किया जाता है, या पेरेंट रिपोर्ट के मापदंडों को सबरेपोर्ट में पारित करने के लिए अंतर्निहित REPORTS_PARAMETERS_MAP पैरामीटर का उपयोग करके। इस एक्सप्रेशन को हमेशा java.util.ap ऑब्जेक्ट पर वापस करना चाहिए जिसमें कुंजियाँ पैरामीटर नाम हैं।

  • <subreportParameter> - इस तत्व का उपयोग सबरपोर्ट के मापदंडों को पास करने के लिए किया जाता है। इसका एक विशेषता नाम है , जो अनिवार्य है।

  • <connectionExpression> - इसका उपयोग java.sql.Connection को subreport में पास करने के लिए किया जाता है । इसका उपयोग केवल तब किया जाता है जब रिपोर्ट भरने के चरण के दौरान सबप्रपोर्ट टेम्पलेट को डेटाबेस कनेक्शन की आवश्यकता होती है।

  • <dataSourceExpression> - इसका उपयोग एक डेटा स्रोत सबरपोर्ट को पास करने के लिए किया जाता है। यह डेटा स्रोत आमतौर पर मास्टर रिपोर्ट में एक पैरामीटर से या सब -पोर्ट के लिए पेरेंट रिपोर्ट के डेटा स्रोत को पास करने के लिए अंतर्निहित REPORT_DATA_SOURCE पैरामीटर का उपयोग करके प्राप्त किया जाता है।

  • तत्व ( connectionExpression और dataSourceExpression ) एक <subreport> तत्व घोषणा में एक ही समय में मौजूद नहीं हो सकते। ऐसा इसलिए है क्योंकि हम डेटा स्रोत और सबरेपोर्ट के लिए कनेक्शन की आपूर्ति नहीं कर सकते हैं। हमें उनमें से एक पर फैसला करना चाहिए और उस पर टिक जाना चाहिए।

  • <returnValue> - यह मास्टर रिपोर्ट के चर में से किसी एक को सबरपोर्ट के चर का मान निर्दिष्ट करने के लिए उपयोग किया जाता है। इस उप तत्व में निम्न प्रकार के गुण हैं -

    • subreportVariable - यह विशेषता सबरपोर्ट वैरिएबल के नाम को निर्दिष्ट करती है जिसका मान वापस करना है।

    • .Variable - यह विशेषता उस मूल रिपोर्ट चर का नाम निर्दिष्ट करती है, जिसका मूल्य कॉपी किया जाना है / जो सब्रेपोर्ट से मान के साथ बढ़ाया गया है।

    • गणना - यह विशेषता मान ले सकती है: कुछ भी नहीं, गणना, डिस्टिंक्टाउंट, सम, औसत, न्यूनतम, उच्चतम, मानक विचलन, भिन्न। विशेषता गणना के लिए डिफ़ॉल्ट मान "कुछ भी नहीं" है।

    • incrementerFactoryClass - यह विशेषता इंक्रीमेंटर इंस्टेंस बनाने के लिए फ़ैक्टरी क्लास को निर्दिष्ट करती है।

  • <subreportExpression> - यह इंगित करता है कि सबरपोर्ट के लिए संकलित रिपोर्ट टेम्पलेट कहां खोजना है। यह तत्व ए हैclassविशेषता। वर्ग java.lang.String, java.io.File, java.net.URL, java.io.InputStream, net.sf.jasperreports.engine.JasperReport: विशेषता इन मूल्यों के किसी भी ले जा सकते हैं। डिफ़ॉल्ट मान java.lang.String है

  • isUsingCache - यह <subreport> तत्व का एक गुण है। यह एक बूलियन है, जब सही पर सेट किया जाता है , तो रिपोर्टिंग इंजन अपने निर्दिष्ट स्रोत का उपयोग करके पहले से लोड किए गए सबपोर्टपोर्ट टेम्प्लेट ऑब्जेक्ट को पहचानने की कोशिश करेगा। यह कैशिंग कार्यक्षमता केवल सबरपोर्ट तत्वों के लिए उपलब्ध है, जिसमें java.lang लौटाने वाले भाव हैं। ऑब्जेक्ट्स को सबप्रपोर्ट टेम्प्लेट स्रोत के रूप में दर्शाते हैं, फ़ाइल नाम, URL या क्लासपैथ संसाधनों का प्रतिनिधित्व करते हैं।

उदाहरण

JRDataSource का उपयोग करके सबप्रोर्ट्स के निर्माण को प्रदर्शित करने के लिए एक सरल उदाहरण लें। चलो पहले दो नए रिपोर्ट टेम्पलेट लिखते हैं, एक सबरपोर्ट और दूसरा मास्टर रिपोर्ट। सबरपोर्ट (address_report_template.jrxml) टेम्प्लेट की सामग्री नीचे दी गई है। इसे C: \ tools \ jasperreports-5.0.1 \ test निर्देशिका में सहेजें।

<?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 = "address_report_template" pageWidth = "175" pageHeight = "842" 
   columnWidth = "175" leftMargin = "0" rightMargin = "0" 
   topMargin = "0" bottomMargin = "0">

   <field name = "city" class = "java.lang.String"/>
   <field name = "street" class = "java.lang.String"/>
   
   <background>
      <band splitType = "Stretch"/>
   </background>
   
   <title>
      <band height = "20" splitType = "Stretch">
         
         <staticText>
            <reportElement x = "0" y = "0" width = "100" height = "20"/>
            
            <textElement>
               <font size = "14" isBold = "true"/>
            </textElement>
				
            <text><![CDATA[Addresses]]></text>
         </staticText>
      
      </band>
   </title>
   
   <pageHeader>
      <band height = "12" splitType = "Stretch"/>
   </pageHeader>
   
   <columnHeader>
      <band height = "12" splitType = "Stretch"/>
   </columnHeader>
   
   <detail>
      <band height = "27" splitType = "Stretch">
         
         <textField>
            <reportElement x = "0" y = "0" width = "120" height = "20"/>
            
            <textElement>
               <font size = "12" isBold = "true"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$F{city}+" Address:"]]>
            </textFieldExpression>
         </textField>
         
         <textField isStretchWithOverflow = "true">
            <reportElement x = "120" y = "0" width = "435" height = "20"/>
            
            <textElement>
               <font size = "12"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$F{street}]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
   
   <columnFooter>
      <band height = "8" splitType = "Stretch"/>
   </columnFooter>
  
   <pageFooter>
      <band height = "11" splitType = "Stretch"/>
   </pageFooter>
   
   <summary>
      <band height = "9" splitType = "Stretch"/>
   </summary>

</jasperReport>

जैसा कि हम एक डेटा स्रोत का उपयोग करते हैं, हमें एक संबंधित POJO फ़ाइल लिखने की आवश्यकता है SubReportBean.java जैसा की नीचे दिखाया गया। इसे निर्देशिका C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint पर सहेजें -

package com.tutorialspoint;

public class SubReportBean {
   private String city;
   private String street;

   public String getCity() {
      return city;
   }

   public void setCity(String city) {
      this.city = city;
   }

   public String getStreet() {
      return street;
   }

   public void setStreet(String street) {
      this.street = street;
   }
}

यहां, हमने दो क्षेत्रों को 'शहर' और 'स्ट्रीट' घोषित किया है और संबंधित गेटटर और सेटर विधियां परिभाषित की गई हैं।

अब, अपने मौजूदा को अपडेट करते हैं DataBeanफ़ाइल। हम एक नया फ़ील्ड सबरपोर्टबिनलिस्ट जोड़ेंगे , जो एक java.util.List है। यह फ़ील्ड SubReportBean ऑब्जेक्ट्स की सूची रखेगा। DataBean फ़ाइल की सामग्री नीचे दी गई है। इसे निर्देशिका C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint पर सहेजें।

package com.tutorialspoint;

import java.util.List;

public class DataBean {
   private String name;
   private String country;
   private List<SubReportBean> subReportBeanList;

   public String getName() {
      return name;
   }

   public void setName(String name) {
      this.name = name;
   }

   public String getCountry() {
      return country;
   }

   public void setCountry(String country) {
      this.country = country;
   }

   public List<SubReportBean> getSubReportBeanList() {
      return subReportBeanList;
   }

   public void setSubReportBeanList(List<SubReportBean> subReportBeanList) {
      this.subReportBeanList = subReportBeanList;
   }
}

आइए अब फाइल को C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint \ _ से अपडेट करेंDataBeanList.java। इस फ़ाइल की सामग्री इस प्रकार हैं -

package com.tutorialspoint;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class DataBeanList {
   public ArrayList<DataBean> getDataBeanList() {

      // Create sub report data
      SubReportBean subBean1 = new SubReportBean();
      subBean1.setCity("Mumbai");
      subBean1.setStreet("M.G.Road");
      SubReportBean subBean2 = new SubReportBean();
      subBean2.setCity("New York");
      subBean2.setStreet("Park Street");
      SubReportBean subBean3 = new SubReportBean();
      subBean3.setCity("San Fransisco");
      subBean3.setStreet("King Street");

      ArrayList<DataBean> dataBeanList = new ArrayList<DataBean>();

      // Create master report data
      dataBeanList.add(produce("Manisha", "India",
         Arrays.asList(subBean1)));
      dataBeanList.add(produce("Dennis Ritchie", "USA",
         Arrays.asList(subBean2)));
      dataBeanList.add(produce("V.Anand", "India",
         Arrays.asList(subBean1)));
      dataBeanList.add(produce("Shrinath", "California",
         Arrays.asList(subBean3)));

      return dataBeanList;
   }

   /*
    * This method returns a DataBean object,
    * with name, country and sub report
    * bean data set in it.
    */
   private DataBean produce(String name, String country,
      List<SubReportBean> subBean) {
      DataBean dataBean = new DataBean();

      dataBean.setName(name);
      dataBean.setCountry(country);
      dataBean.setSubReportBeanList(subBean);

      return dataBean;
   }
}

उपरोक्त फ़ाइल में विधि उत्पादन () में, हम SubReportBean की सूची सेट कर रहे हैं।

अब, एक नया मास्टर रिपोर्ट टेम्पलेट (jasper_report_template.jrxml) लिखें। इस फ़ाइल को निर्देशिका में सहेजेंC:\tools\jasperreports-5.0.1\test। इस फ़ाइल की सामग्री इस प्रकार है -

<?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 = "jasper_report_template" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth ="555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">

   <parameter name = "SUBREPORT_DIR" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression>
         <![CDATA["C:\\tools\\jasperreports-5.0.1\\test\\"]]>
      </defaultValueExpression>
   </parameter>
   
   <field name = "country" class = "java.lang.String"/>
   <field name = "name" class = "java.lang.String"/>
   <field name = "subReportBeanList" class = "java.util.List"/>
   
   <background>
      <band splitType = "Stretch"/>
   </background>
   
   <title>
      <band height = "35" splitType = "Stretch">
         
         <staticText>
            <reportElement x = "0" y = "0" width = "204" height = "34"/>
            
            <textElement>
               <font size = "26" isBold = "true"/>
            </textElement>
				
            <text><![CDATA[Contact Report]]></text>
         </staticText>
      
      </band>
   </title>
   
   <pageHeader>
      <band height = "17" splitType = "Stretch"/>
   </pageHeader>
   
   <columnHeader>
      <band height = "21" splitType = "Stretch"/>
   </columnHeader>
   
   <detail>
      <band height = "112" splitType = "Stretch">
            
         <staticText>
            <reportElement x = "0" y = "0" width = "100" height = "20"/>
            
            <textElement>
               <font size = "12" isBold = "true"/>
            </textElement>
				
            <text><![CDATA[Name:]]></text>
         </staticText>
         
         <staticText>
            <reportElement x = "0" y = "20" width = "100" height = "20"/>
            
            <textElement>
               <font size = "12" isBold = "true"/>
            </textElement>
				
            <text><![CDATA[Country:]]></text>
         </staticText>
         
         <textField>
            <reportElement x = "104" y = "0" width = "277" height = "20"/>
            
            <textElement>
               <font size = "12"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$F{name}]]>
            </textFieldExpression>
         </textField>
         
         <textField>
            <reportElement x = "104" y = "20" width = "277" height = "20"/>
            
            <textElement>
               <font size = "12"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$F{country}]]>
            </textFieldExpression>
         </textField>
         
         <subreport>
            <reportElement positionType = "Float" x = "335" y = "25" width = "175"
               height = "20" isRemoveLineWhenBlank = "true" backcolor = "#99ccff"/>

            <dataSourceExpression>
               new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource
                  ($F{subReportBeanList})
            </dataSourceExpression>
            
            <subreportExpression class = "java.lang.String">
               <![CDATA[$P{SUBREPORT_DIR} + "address_report_template.jasper"]]>
            </subreportExpression>
         </subreport>
         
         <line>
            <reportElement x = "0" y = "50" width = "550" height = "1"/>
         </line>
      
      </band>
   </detail>
   
   <columnFooter>
      <band height = "19" splitType = "Stretch"/>
   </columnFooter>
   
   <pageFooter>
      <band height = "18" splitType = "Stretch"/>
   </pageFooter>
   
   <summary>
      <band height = "14" splitType = "Stretch"/>
   </summary>

</jasperReport>

उपरोक्त टेम्पलेट में, हमने एक नया पैरामीटर "SUBREPORT_DIR" परिभाषित किया है, जो सबरपोर्ट के मार्ग को परिभाषित करता है। हमने एक फ़ील्ड subReportBeanList को java.util.List के रूप में परिभाषित किया है , जो फ़ाइल DataBean में संपत्ति से मेल खाती है। तत्व <सबरपोर्ट> में उप-तत्व है <dataSourceExpression>। हमने JRBeanCollectionDataSource के एक उदाहरण में सूची subReportBeanList लगाई है। उप-तत्व <subreportExpression /> में, हमने सबरपोर्ट नाम (AddressReport.jasper) दिया है।

अब, एक नया वर्ग लिखते हैं CreateReportहमारे रिपोर्ट टेम्पलेट को संकलित और निष्पादित करने के लिए। फ़ाइल की सामग्रीC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\CreateReport.java नीचे दिए गए हैं -

package com.tutorialspoint;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;

import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperCompileManager;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.JasperReport;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;

public class CreateReport {

   public static void main(String[] args) {
      String masterReportFileName = "C://tools/jasperreports-5.0.1/test"
         + "/jasper_report_template.jrxml";
      String subReportFileName = "C://tools/jasperreports-5.0.1/test"
         + "/AddressReport.jrxml";
      String destFileName = "C://tools/jasperreports-5.0.1/test"
         + "/jasper_report_template.JRprint";
			
      DataBeanList DataBeanList = new DataBeanList();
      ArrayList<DataBean> dataList = DataBeanList.getDataBeanList();
      JRBeanCollectionDataSource beanColDataSource = new 
         JRBeanCollectionDataSource(dataList);

      try {
         /* Compile the master and sub report */
         JasperReport jasperMasterReport = JasperCompileManager
            .compileReport(masterReportFileName);
         JasperReport jasperSubReport = JasperCompileManager
            .compileReport(subReportFileName);

         Map<String, Object> parameters = new HashMap<String, Object>();
         parameters.put("subreportParameter", jasperSubReport);
         JasperFillManager.fillReportToFile(jasperMasterReport, 
            destFileName, parameters, beanColDataSource);

      } catch (JRException e) {

         e.printStackTrace();
      }
      System.out.println("Done filling!!! ...");
   }
}

यहां, हम देखते हैं कि हम मास्टर और उप रिपोर्ट टेम्पलेट दोनों को संकलित कर रहे हैं और रिपोर्ट भरने के लिए मास्टर रिपोर्ट (.jper) फ़ाइल पास कर रहे हैं।

रिपोर्ट पीढ़ी

अब, हमारी सभी फाइलें तैयार हैं, आइए हमारी नियमित ANT निर्माण प्रक्रिया का उपयोग करके उन्हें संकलित करें और निष्पादित करें। फ़ाइल build.xml (निर्देशिका C: \ tools \ jasperreports-5.0.1 \ test के तहत सहेजी गई) की सामग्री नीचे दी गई है।

आयात फ़ाइल - baseBuild.xml को अध्याय पर्यावरण सेटअप से उठाया गया है और इसे बिल्ड .xml के समान निर्देशिका में रखा जाना चाहिए।

<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "viewFillReport" basedir = ".">
   <import file = "baseBuild.xml" />
   
   <target name = "viewFillReport" depends = "compile,compilereportdesing,run"
      description = "Launches the report viewer to preview the 
      report stored in the .JRprint file.">
      
      <java classname = "net.sf.jasperreports.view.JasperViewer" fork = "true">
         <arg value = "-F${file.name}.JRprint" />
         <classpath refid = "classpath" />
      </java>
   </target>
   
   <target name = "compilereportdesing" description = "Compiles the JXML file and
      produces the .jasper file.">
      
      <taskdef name = "jrc" classname = "net.sf.jasperreports.ant.JRAntCompileTask">
         <classpath refid = "classpath" />
      </taskdef>
      
      <jrc destdir = ".">
         <src>
            <fileset dir = ".">
               <include name = "*.jrxml" />
            </fileset>
         </src>
         <classpath refid = "classpath" />
      </jrc>
		
   </target>

</project>

अगला, चलो कमांड लाइन विंडो खोलें और उस निर्देशिका पर जाएं जहां build.xml रखा गया है। अंत में, कमांड निष्पादित करेंant -Dmain-class=com.tutorialspoint.CreateReport (viewFullReport डिफ़ॉल्ट लक्ष्य है) निम्नानुसार है -

Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml

clean-sample:
   [delete] Deleting directory C:\tools\jasperreports-5.0.1\test\classes

compile:
   [mkdir] Created dir: C:\tools\jasperreports-5.0.1\test\classes
   [javac] C:\tools\jasperreports-5.0.1\test\baseBuild.xml:28: 
      warning: 'includeantruntime' was not set, defaulting to
   [javac] Compiling 7 source files to C:\tools\jasperreports-5.0.1\test\classes

compilereportdesing:
   [jrc] Compiling 1 report design files.
   [jrc] log4j:WARN No appenders could be found for logger
   (net.sf.jasperreports.engine.xml.JRXmlDigesterFactory).
   [jrc] log4j:WARN Please initialize the log4j system properly.
   [jrc] log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig 
      for more info.
   [jrc] File : C:\tools\jasperreports-5.0.1\test\
      jasper_report_template.jrxml ... OK.

run:
   [echo] Runnin class : com.tutorialspoint.CreateReport
   [java] Compiling Report Design ...
   [java] log4j:WARN No appenders could be found for logger
   (net.sf.jasperreports.engine.xml.JRXmlDigesterFactory).
   [java] log4j:WARN Please initialize the log4j system properly.
   [java] Done filling!!! ...

viewFillReport:
   [java] log4j:WARN No appenders could be found for logger
   (net.sf.jasperreports.extensions.ExtensionsEnvironment).
   [java] log4j:WARN Please initialize the log4j system properly.

BUILD SUCCESSFUL
Total time: 72 minutes 13 seconds

उपरोक्त संकलन के परिणामस्वरूप, जैस्परव्यूअर विंडो खुलती है जैसा कि नीचे दी गई स्क्रीन में दिखाया गया है -

यहाँ, हम देख सकते हैं कि विशेषताएँ नाम, देश और पता प्रदर्शित हैं।