एक्सेल डैक्स - मूल्यांकन संदर्भ
DAX फॉर्मूला लिखते समय DAX में, संदर्भ एक महत्वपूर्ण शब्द है जिसके बारे में आपको जानकारी होनी चाहिए। के रूप में भी संदर्भित हैevaluation context, DAX संदर्भ का उपयोग DAX सूत्र और इसी परिणाम के मूल्यांकन को निर्धारित करने के लिए किया जाता है। इसका अर्थ है, DAX सूत्र के परिणाम संदर्भ के अनुसार भिन्न हो सकते हैं। आपको स्पष्ट रूप से समझना चाहिए कि एक विशिष्ट DAX संदर्भ का उपयोग कैसे किया जाता है और परिणाम कैसे भिन्न हो सकते हैं।
मूल्यांकन संदर्भ आपको गतिशील विश्लेषण करने में सक्षम बनाता है, जिसमें एक DAX सूत्र के परिणाम वर्तमान पंक्ति या सेल चयन और किसी भी संबंधित डेटा को प्रतिबिंबित करने के लिए बदल सकते हैं। संदर्भ को समझना और प्रभावी रूप से DAX सूत्र बनाने के लिए संदर्भ का उपयोग करना बहुत महत्वपूर्ण है, गतिशील डेटा विश्लेषण करना और DAX सूत्रों में समस्याओं का निवारण करना। मूल्यांकन संदर्भ DAX की उन सभी उन्नत विशेषताओं के आधार हैं जिन्हें आपको जटिल डेटा विश्लेषण रिपोर्ट बनाने के लिए मास्टर करने की आवश्यकता है।
जब आप DAX फ़ार्मुलों में प्रासंगिक उपयोग के लिए DAX फ़ंक्शंस का संदर्भ लेते हैं, तो आपको परिणामों पर स्पष्टता प्राप्त करने के लिए DAX संदर्भ पर इस अध्याय को संदर्भित करना होगा।
DAX में प्रसंग के प्रकार
DAX निम्नलिखित मूल्यांकन संदर्भों का समर्थन करता है -
- पंक्ति प्रसंग
- फ़िल्टर संदर्भ
जब एक DAX सूत्र का मूल्यांकन किया जाता है, तो सभी संदर्भों को ध्यान में रखा जाएगा और प्रासंगिक के रूप में लागू किया जाएगा। संदर्भ एक साथ मौजूद हैं और सूत्र का परिणाम उस संदर्भ के आधार पर अलग होगा जो किसी मूल्य की गणना करते समय उपयोग किया जाता है। उदाहरण के लिए, जब आप PivotTable में पंक्तियों, स्तंभों और फ़िल्टरों के लिए फ़ील्ड चुनते हैं, तो सबटोटल्स की गणना गतिशील रूप से की जाती है कि किस पंक्ति और किस स्तंभ पर उप-योग / कुल जुड़ा होता है और पंक्तियों और स्तंभों में मान फ़िल्टर द्वारा निर्धारित किए जाते हैं उपयोग किया गया।
पंक्ति प्रसंग
पंक्ति संदर्भ का अर्थ है कि DAX सूत्र या DAX फ़ंक्शन जानता है कि तालिका की कौन सी पंक्ति किसी भी समय संदर्भित हो रही है। आप पंक्ति संदर्भ को वर्तमान पंक्ति मान सकते हैं। सूत्र को पंक्ति संदर्भ द्वारा पंक्ति-दर-पंक्ति मिल जाएगा।
कुछ DAX फ़ंक्शंस (जैसे, X- फ़ंक्शंस, फ़िल्टर) () और सभी परिकलित स्तंभों में एक पंक्ति संदर्भ होता है। उदाहरण के लिए, यदि आप DAX सूत्र = YEAR ([दिनांक]) के साथ परिकलित स्तंभ वर्ष बनाते हैं, तो गणना स्तंभ का मान तालिका में दिए गए स्तंभ पर दिए गए DAX सूत्र को लागू करके प्राप्त किया जाता है, पंक्ति द्वारा पंक्ति।
इसका मतलब यह है कि यदि आपने एक परिकलित स्तंभ बनाया है, तो पंक्ति संदर्भ में प्रत्येक व्यक्तिगत पंक्ति में मान और वर्तमान पंक्ति से संबंधित स्तंभों में मान शामिल होते हैं, जैसा कि DAX सूत्र द्वारा निर्धारित किया जाता है। हालाँकि DAX सूत्र में किसी पंक्ति का संदर्भ नहीं है, फिर भी DAX मानों की गणना करते समय पंक्ति के संदर्भ को स्पष्ट रूप से समझता है।
जब आप किसी परिकलित स्तंभ को परिभाषित करते हैं तो DAX एक पंक्ति संदर्भ बनाता है और उपयोग किए गए DAX सूत्र के साथ सभी परिकलित मान परिकलित स्तंभ में दिखाई देंगे।
इसके विपरीत, जब आपके पास SAXX जैसे DAX फ़ंक्शन होता है, तो पंक्ति द्वारा गणना की गई मानों को सारांशित किया जाता है और केवल अंतिम परिणाम प्रदर्शित किया जाएगा। यही है, मध्यवर्ती मूल्यों को त्याग दिया जाता है।
जब आपके पास संबंधित टेबल होते हैं, तो पंक्ति संदर्भ यह निर्धारित करता है कि संबंधित तालिका में कौन सी पंक्तियां वर्तमान पंक्ति से जुड़ी हैं। हालाँकि, पंक्ति संदर्भ स्वचालित रूप से रिश्तों के माध्यम से नहीं फैलता है। आपको इसके लिए DAX फ़ंक्शंस का उपयोग करना होगा - संबंधित और संबंधित।
एकाधिक पंक्ति प्रसंग
DAX में SUMX जैसे पुनरावृत्त कार्य होते हैं। आप इन फ़ंक्शन का उपयोग पंक्ति संदर्भों को घोंसला बनाने के लिए कर सकते हैं। इसके साथ, प्रोग्रामेटिक रूप से आपके पास एक आंतरिक लूप और एक बाहरी लूप पर एक पुनरावृत्ति हो सकती है, जहां आपके पास कई वर्तमान पंक्तियाँ और वर्तमान पंक्ति संदर्भ हो सकते हैं।
उदाहरण के लिए, आप DAX फ़ंक्शन का उपयोग पहले () कर सकते हैं जो वर्तमान ऑपरेशन से पहले के पंक्ति संदर्भ को संग्रहीत करता है। यह फ़ंक्शन मेमोरी में संदर्भ के दो सेटों को संग्रहीत करता है - संदर्भ का एक सेट सूत्र के आंतरिक लूप के लिए वर्तमान पंक्ति का प्रतिनिधित्व करता है, और संदर्भ का एक अन्य सेट सूत्र के बाहरी लूप के लिए वर्तमान पंक्ति का प्रतिनिधित्व करता है। DAX स्वचालित रूप से दो छोरों के बीच के मूल्यों को खिलाता है ताकि आप जटिल समुच्चय बना सकें।
एक उदाहरण के लिए, परिदृश्य का संदर्भ लें - एक DAX फॉर्मूला बनाना जो कि डायनामिक रूप से अध्याय परिदृश्य में मानों को रैंकिंग देता है - रैंकिंग और तुलनात्मक मूल्य।
फ़िल्टर संदर्भ
फ़िल्टर संदर्भ किसी भी फ़िल्टरिंग को संदर्भित करता है जो DAX में डेटा मॉडल पर लागू होता है। फ़िल्टर संदर्भ PivotTable द्वारा और DAX फ़ंक्शंस द्वारा भी बनाया गया है।
फ़िल्टर संदर्भ एक PivotTable द्वारा बनाया गया
PivotTable द्वारा बनाया गया फ़िल्टर संदर्भ वह प्राकृतिक फ़िल्टरिंग है जो PivotTable फ़ील्ड्स पर निम्नलिखित में से चयनों द्वारा लागू किया जाता है -
- Rows
- Columns
- Filters
- Slicers
PivotTable द्वारा बनाया गया फ़िल्टर संदर्भ, डेटा मॉडल में अंतर्निहित तालिकाओं को फ़िल्टर करता है। यदि टेबल संबंधित हैं, तो फ़िल्टर लुकअप टेबल से डेटा टेबल तक नीचे प्रवाहित होते हैं। इसका मतलब है, आप लुकअप तालिकाओं से परिणामों के आधार पर डेटा तालिकाओं को फ़िल्टर कर सकते हैं। फ़िल्टर प्रसार दूसरे तरीके से नहीं होता है। हालाँकि, आप डेटा तालिका से परिणामों के आधार पर लुकअप तालिकाओं को फ़िल्टर करने के लिए DAX सूत्र का उपयोग कर सकते हैं।
DAX फ़ंक्शंस द्वारा बनाया गया फ़िल्टर संदर्भ
DAX सूत्र द्वारा उपयोग किए गए मानों को नियंत्रित करने वाले फ़िल्टर अभिव्यक्तियों वाले परिकलित फ़ील्ड और परिकलित स्तंभों को परिभाषित करने के लिए आप DAX फ़िल्टर फ़ंक्शंस का उपयोग कर सकते हैं। ये परिकलित फ़ील्ड और परिकलित स्तंभ फिर PivotTable फ़ील्ड सूची का हिस्सा बन जाते हैं और आप इन्हें PivotTable में जोड़ सकते हैं। आप इन DAX फ़िल्टर फ़ंक्शंस के साथ विशेष कॉलम पर फ़िल्टर्स को चुनिंदा रूप से साफ़ कर सकते हैं। फ़िल्टर संदर्भ बनाने के लिए एक शक्तिशाली DAX फ़िल्टर फ़ंक्शन का एक उदाहरण CALCULATE () है। एक उदाहरण के लिए, अध्याय परिदृश्य - जटिल गणना प्रदर्शन करना देखें।
रो कॉनटेक्स्ट के एक एडिशन के तौर पर फिल्टर कॉनटेक्स्ट
पंक्ति संदर्भ स्वचालित रूप से फ़िल्टर संदर्भ नहीं बनाता है। आप DAX फ़िल्टर फ़ंक्शंस वाले DAX फ़ार्मुलों के साथ इसे प्राप्त कर सकते हैं।