एक्सेल डैक्स - फॉर्मूला त्रुटियां

लिखते समय आपको त्रुटियाँ मिल सकती हैं DAX formulasगलत वाक्य रचना के साथ। परिकलित फ़ील्ड और परिकलित स्तंभों में DAX फ़ंक्शंस हो सकते हैं जिनके लिए एक विशिष्ट प्रकार के तर्कों की आवश्यकता होती है। DAX फ़ंक्शंस के तर्क टेबल, कॉलम या अन्य DAX फ़ंक्शंस (नेस्टेड DAX फ़ंक्शंस) हो सकते हैं। चूंकि DAX फ़ंक्शंस टेबल और कॉलम लौटा सकती हैं, यह ध्यान रखने के लिए ध्यान रखा जाना चाहिए कि DAX फ़ंक्शंस में सही प्रकार के तर्क पास किए गए हों।

DAX सूत्र त्रुटियाँ या तो सिंटैक्स त्रुटियाँ या शब्दार्थ त्रुटियाँ हो सकती हैं। त्रुटियाँ डिज़ाइन समय पर या रन समय पर हो सकती हैं।

इस अध्याय में, आप कुछ सामान्य DAX त्रुटियों, उनके कारणों और उन त्रुटियों को ठीक करने के तरीके के बारे में जानेंगे।

DAX त्रुटि: गणना निरस्त

निम्नलिखित त्रुटि तब हो सकती है जब DAX समय-खुफिया फ़ंक्शन के साथ परिकलित फ़ील्ड बनाने (डिज़ाइन-समय) या उपयोग (रन-टाइम) परिकलित फ़ील्ड का उपयोग करने का प्रयास किया जाता है। प्रत्येक मामले में, एक गैर-अनौपचारिक दिनांक सीमा को समय खुफिया कार्य के लिए पारित किया जा रहा है।

"DAX त्रुटि: कैलिब्रेटेड ABEDED: MdxScript (उदाहरण) (00, 0) फ़ंक्शन 'DATEADD' केवल सन्निहित तिथि चयन के साथ काम करता है।"

रन-टाइम पर कारण

यह त्रुटि तब दिखाई दे सकती है जब एक DAX समय खुफिया फ़ंक्शन के साथ परिकलित फ़ील्ड को PivotTable और दिनांक फ़ील्ड जैसे VALUES क्षेत्र में रखा जाता है, जैसे कि महीने या तिमाही को एक वर्ष चुनने से पहले स्लाइसर्स या फ़िल्टर के रूप में चुना जाता है। उदाहरण के लिए, यदि आपके पास तीन वर्ष - 2014, 2015, और 2016 के आंकड़े हैं और आप वर्ष क्षेत्र का चयन किए बिना केवल मार्च मार्च का उपयोग करने का प्रयास करते हैं, तो मान सन्निहित डेटा मान नहीं हैं और आपको एक त्रुटि मिलेगी।

रन-टाइम पर त्रुटि कैसे ठीक करें?

उपरोक्त उदाहरण में,

  • पहले एक स्लाइसर या एक फिल्टर के रूप में वर्ष जोड़ें और एक वर्ष का चयन करें।

  • फिर, मंथ या क्वार्टर को स्लाइसर या फिल्टर के रूप में जोड़ें।

  • फिर, चुने गए वर्ष के लिए स्लाइस या फ़िल्टर करने के लिए एक या अधिक महीने या तिमाहियों का चयन करें।

डिजाइन-समय पर कारण

DAX समय खुफिया फ़ंक्शन को दिनांक तर्क के लिए निर्दिष्ट दिनांक स्तंभ की आवश्यकता होती है। दिनांक स्तंभ में दिनांक की एक सन्निहित सीमा होनी चाहिए। यह त्रुटि वापस की जा सकती है, यदि दिनांक स्तंभ में एक या अधिक पंक्तियों में एक दिनांक मान है जो पिछली और क्रमिक पंक्तियों में डेटा मानों के साथ सन्निहित नहीं है।

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

डिज़ाइन-टाइम पर इस त्रुटि को कैसे ठीक करें?

डिज़ाइन समय पर त्रुटि को ठीक करने के लिए निम्न कार्य करें -

  • यदि आपकी दिनांक तालिका किसी डेटा स्रोत से आयात की जाती है, तो स्रोत पर पाए गए किसी भी परिवर्तन को फिर से देखने के लिए Power Pivot विंडो में ताज़ा करें का उपयोग करें।

  • यह सुनिश्चित करने के लिए कि वे एक सन्निहित क्रम में हैं, अपनी तिथि कॉलम के मानों की जाँच करें। यदि कोई मान नहीं पाया जाता है, तो इसे स्रोत पर सही करना होगा और तारीख तालिका को ताज़ा करना होगा।

  • अपने डेटा मॉडल में एक अलग दिनांक तालिका और दिनांक स्तंभ बनाएँ। त्रुटि के कारण सूत्र में दिनांक तर्क के रूप में नया दिनांक स्तंभ निर्दिष्ट करें। डेट टेबल बनाना और डेटा मॉडल में जोड़ना आसान है।

DAX शब्दार्थ त्रुटि - एक उदाहरण

निम्नलिखित DAX त्रुटि एक शब्दार्थ त्रुटि है -

“एक फ़ंक्शन a CALCULATE’ का उपयोग एक सच्चे-झूठी अभिव्यक्ति में किया गया है जिसका उपयोग टेबल फ़िल्टर अभिव्यक्ति के रूप में किया जाता है। इसकी अनुमति नहीं है। ”

वजह

यह त्रुटि तब दिखाई दे सकती है जब एक या अधिक फ़िल्टर अभिव्यक्तियों का उपयोग परिकलित फ़ील्ड या परिकलित स्तंभ अभिव्यक्ति के संदर्भ में नहीं किया जा सकता है।

अधिकांश मामलों में, यह त्रुटि DAX CALCULATE फ़ंक्शन के तर्क के रूप में निर्दिष्ट फ़िल्टर अभिव्यक्ति के कारण होती है। CALCULATE फ़ंक्शन को बूलियन एक्सप्रेशन या टेबल एक्सप्रेशन के रूप में परिभाषित फिल्टर की आवश्यकता होती है।

ऐसे त्रुटियों को कैसे ठीक करें?

आप फ़िल्टर को टेबल एक्सप्रेशन के रूप में परिभाषित करने के लिए DAX फिल्टर फ़ंक्शन का उपयोग करके ऐसी त्रुटियों को ठीक कर सकते हैं, जिसे तब DAX CALCULATE फ़ंक्शन के तर्क के रूप में उपयोग किया जा सकता है।