डेटा स्रोतों की रिपोर्ट करें

डेटा स्रोत संरचित डेटा कंटेनर हैं। रिपोर्ट को जनरेट करते समय, जैस्पररीपोर्ट इंजन डेटा स्रोत से डेटा प्राप्त करता है। डेटा डेटाबेस, एक्सएमएल फाइलों, वस्तुओं के सरणियों और वस्तुओं के संग्रह से प्राप्त किया जा सकता है। हमने अध्याय भरने की रिपोर्ट में देखा , fillReportXXX () विधि रिपोर्ट के डेटा स्रोत को प्राप्त करने की उम्मीद करती है, जिसे भरना है, के रूप मेंnet.sf.jasperreports.engine.JRDataSource वस्तु या ए java.sql.Connection (जब रिलेशनल डेटाबेस में रिपोर्ट डेटा पाया जाता है)।

JRDataSource इंटरफ़ेस में केवल दो विधियाँ हैं, जिन्हें लागू किया जाना चाहिए -

  • सार्वजनिक बूलियन अगले () JRException फेंकता है;

    • रिपोर्ट भरने के समय, डेटा के माध्यम से पुनरावृत्ति करते समय रिपोर्टिंग विधि द्वारा डेटा स्रोत ऑब्जेक्ट पर इस पद्धति को कॉल किया जाता है।

  • सार्वजनिक ऑब्जेक्ट getFieldValue (JRField jrField) JRException को फेंकता है;

    • यह विधि वर्तमान डेटा स्रोत रिकॉर्ड में प्रत्येक रिपोर्ट फ़ील्ड के लिए मान प्रदान करती है।

डेटा स्रोत से डेटा पुनर्प्राप्त करने का एकमात्र तरीका रिपोर्ट फ़ील्ड का उपयोग करके है। JRDataSource इंटरफ़ेस के कई डिफ़ॉल्ट कार्यान्वयन हैं, जिस तरह से, डेटा स्रोत में रिकॉर्ड्स का अधिग्रहण किया जाता है।

डेटास्रोस कार्यान्वयन

नीचे दी गई तालिका डेटा स्रोत और उनके कार्यान्वयन वर्गों को सारांशित करती है -

डेटा स्रोत कार्यान्वयन वर्ग
JDBC net.sf.jasperreports.engine.JRResultSetDataSource
JavaBean net.sf.jasperreports.engine.data.JRBeanCollectionDataSource, net.sf.jasperreports.engine.data.JRBeanArrayDataSource
मानचित्र के आधार पर net.sf.jasperreports.engine.data.JRMapArrayDataSource, net.sf.jasperreports.engine.data.JRMapCollectionDataSource
TableModel net.sf.jasperreports.engine.data.JRTableModelDataSource
एक्सएमएल net.sf.jasperreports.engine.data.JRXmlDataSource
सीएसवी net.sf.jasperreports.engine.data.JRCsvDataSource
XLS net.sf.jasperreports.engine.data.JRXlsDataSource
खाली net.sf.jasperreports.engine.JREmptyDataSource

JDBC डेटा स्रोत

कक्षा JRResultSetDataSourceक्रेप्स a java.sql.ResultSet ऑब्जेक्ट। जब किसी रिलेशनल डेटाबेस से रिपोर्ट डेटा निकाला जाता है तो यह सबसे अधिक उपयोग किया जाने वाला डेटा स्रोत कार्यान्वयन है। यदि java.sql.Connection को इंजन के बजाय पास किया जाता है, तो यह पहले संबंधित क्वेरी को निष्पादित करता है और JRResultSetDataSource उदाहरण में java.sql.ResultSet ऑब्जेक्ट को संग्रहीत करता है ।

जावाबीन डेटा स्रोत

कक्षाओं JRBeanArrayDataSource तथा JRBeanCollectionDataSourceउन कार्यान्वयनों का प्रतिनिधित्व करते हैं जो JavaBean वस्तुओं के सरणियों और संग्रहों को लपेट सकते हैं। सरणी या संग्रह के अंदर प्रत्येक ऑब्जेक्ट को इस प्रकार के डेटा स्रोत में एक रिकॉर्ड के रूप में देखा जाएगा। एक विशेष JavaBean संपत्ति और संबंधित रिपोर्ट फ़ील्ड के बीच मानचित्रण नामकरण सम्मेलनों द्वारा किया जाता है। रिपोर्ट फ़ील्ड का नाम JavaBean संपत्ति के नाम के समान होना चाहिए जैसा कि JavaBeans विनिर्देशों द्वारा निर्दिष्ट किया गया है।

इस ट्यूटोरियल के सभी उदाहरणों में, हमने JRBeanCollectionDataSource का उपयोग किया है।

मानचित्र-आधारित डेटा स्रोत

कार्यान्वयन कक्षाएं JRMapArrayDataSource तथा JRMapCollectionDataSourceयदि माता-पिता एप्लिकेशन पहले से ही उपलब्ध डेटा को मेमोरी में java.util.Map ऑब्जेक्ट के रूप में संग्रहीत करते हैं, तो उपयोगी होते हैं । लिपटे हुए सरणी या संग्रह में प्रत्येक मैप ऑब्जेक्ट को डेटा स्रोत में एक आभासी रिकॉर्ड माना जाता है, और प्रत्येक रिपोर्ट फ़ील्ड का मान कुंजी से रिपोर्ट किए गए फ़ील्ड का उपयोग करके मैप से निकाला जाता है।

TableModel डेटा स्रोत

कई क्लाइंट-साइड एप्लिकेशन में, डेटा सारणीबद्ध प्रारूप में प्रदर्शित होता है। कई अनुप्रयोगों में एक सामान्य आवश्यकता उपयोगकर्ता को रिपोर्ट के रूप में इस सारणीबद्ध प्रारूप को मुद्रित करने की अनुमति देती है। कार्यान्वयन वर्गJRTableModelDataSourceस्विंग अनुप्रयोगों के लिए सारणीबद्ध प्रारूप से रिपोर्ट बनाने का कार्य करता है। यह वर्ग एक javax.swing.table.TableModel ऑब्जेक्ट लपेटता है। लिपटे TableModel ऑब्जेक्ट में कॉलम या तो उनके नाम या उनके 0-आधारित अनुक्रमित द्वारा पहुँचा जा सकता है।

XML डेटा स्रोत

कक्षा JRXmlDataSourceDOM पर आधारित एक डेटा स्रोत कार्यान्वयन है, जो XML दस्तावेज़ से डेटा का चयन करने के लिए XPath अभिव्यक्तियों का उपयोग करता है। XML डेटा स्रोत में रिकॉर्ड XPath अभिव्यक्ति के माध्यम से चुने गए नोड तत्वों द्वारा दर्शाए जाते हैं। फ़ील्ड विवरण प्रत्येक विवरण से क्षेत्र विवरण (JRXML में <fieldDescription> तत्व) द्वारा प्रदान की गई XPath अभिव्यक्ति का उपयोग करके प्राप्त किया जाता है।

XPath एक भाषा है जिसका उपयोग XML दस्तावेज़ की विशेषताओं और तत्वों के माध्यम से नेविगेट करने के लिए किया जाता है। XPath के बारे में अधिक जानकारी पर पाया जा सकता हैhttp://www.w3.org/TR/xpath.

सीएसवी डेटा स्रोत

JRCsvDataSourceडेटा स्रोतों के लिए एक कार्यान्वयन का प्रतिनिधित्व करता है, जो संरचित पाठ फ़ाइलों से अपने डेटा को पुनर्प्राप्त करता है; आमतौर पर सी.एस.वी. फ़ील्ड मानों को उनके स्तंभ अनुक्रमणिका का उपयोग करके पुनर्प्राप्त किया जाता है।

XLS डेटा स्रोत

JRXlsDataSourceडेटा स्रोतों के लिए एक कार्यान्वयन का प्रतिनिधित्व करता है, जो एक्सेल दस्तावेजों से उनके डेटा को पुनः प्राप्त करते हैं। इस डेटा स्रोत के कार्यान्वयन के लिए रिपोर्ट-फ़ील्ड मैपिंग फ़ील्ड कॉलम इंडेक्स पर भी आधारित है।

खाली डेटा स्रोत

कक्षा JREmptyDataSource, किसी डेटा स्रोत को वर्चुअल खाली अभिलेखों के अंदर एक डेटा स्रोत का अनुकरण करता है। यह यूआई टूल द्वारा बुनियादी रिपोर्ट पूर्वावलोकन कार्यक्षमता, या विशेष रिपोर्ट टेम्पलेट्स में, या परीक्षण और डीबगिंग उद्देश्यों के लिए उपयोग किया जाता है।

प्रतिशोधी डेटा स्रोत

net.sf.jasperreports.engine.JRRewindableDataSourceमूल JRDataSource इंटरफ़ेस का विस्तार करता है। यह केवल एक विधि जोड़ता है, जिसे MoveFirst () कहा जाता है, इंटरफ़ेस में। इस विधि का उद्देश्य डेटासोर्स में पहले तत्व पर कर्सर ले जाना है।

रिवाइंड करने योग्य डेटा स्रोत तब उपयोगी होते हैं जब एक बैंड के अंदर रखी सब-रिपोर्ट के साथ काम किया जाता है जिसे isSplitAllowed = "गलत" सेटिंग के कारण विभाजित करने की अनुमति नहीं होती है और उप-रिपोर्ट को प्रस्तुत करने के लिए वर्तमान पृष्ठ पर पर्याप्त स्थान नहीं है।

उपरोक्त सभी डेटा स्रोत कार्यान्वयन केवल को छोड़कर, इसके लिए ठीक हैं JRResultSetDataSource, क्योंकि यह रिकॉर्ड पॉइंटर को पीछे ले जाने का समर्थन नहीं करता है। यह समस्या तब होती है जब यह डेटा स्रोत मैन्युअल रूप से java.sql.ResultSet को लपेटने के लिए उपयोग किया जाता है, इसे उप-रिपोर्ट में भेजने से पहले। कोई समस्या नहीं है, यदि SQL क्वेरी उप-रिपोर्ट टेम्पलेट में रहती है, क्योंकि इंजन अगले पृष्ठ पर उप-रिपोर्ट को पुनरारंभ करते समय इसे फिर से निष्पादित करेगा।

डेटा स्रोत प्रदाता

JasperReports लाइब्रेरी में एक इंटरफ़ेस है net.sf.jasperreports.engine.JRDataSourceProvider। यह डेटा स्रोत ऑब्जेक्ट बनाने और निपटाने में मदद करता है। GUI टूल का उपयोग करके रिपोर्ट टेम्पलेट बनाते समय, रिपोर्ट के डेटा स्रोत को कस्टमाइज़ करने के लिए एक विशेष टूल की आवश्यकता होती है। JRDataSourceProvider कस्टम डेटा स्रोतों को डिज़ाइन टूल में प्लग करने का मानक तरीका है। इस इंटरफ़ेस का एक कस्टम कार्यान्वयन निम्नलिखित विधियों को लागू करना चाहिए जो डेटा स्रोत ऑब्जेक्ट बनाने और निपटाने की अनुमति देते हैं और यदि संभव हो तो डेटा स्रोत के भीतर उपलब्ध रिपोर्ट फ़ील्ड को सूचीबद्ध करने के लिए तरीके भी -

public boolean supportsGetFieldsOperation();

public JRField[] getFields(JasperReport report)
   throws JRException, UnsupportedOperationException;

public JRDataSource create(JasperReport report) throws JRException;

public void dispose(JRDataSource dataSource) throws JRException;