همه دسته بندی ها
مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

مدل جدولی (Tabular model) در پاور بی ای

مدل جدولی (Tabular model) در پاور بی ای

Power BI و خدمات تحلیلی بر یک مدل معنایی مبتنی بر مدل شیء جدولی (TOM) تکیه دارند.

اگرچه ابزارهای مختلفی برای دستکاری این مدل‌ها وجود دارد – ما استفاده از ویرایشگر جدولی را پیشنهاد می‌کنیم – مفاهیم اساسی یکسان هستند زیرا موتور و مدل داده یکسان هستند: ما آن را مدل جدولی می‌نامیم.

این مقاله بر اساس بخشی از راهنمای قطعی DAX (ویرایش دوم) و انواع مختلف روابط چند به چند در Power BI است.

در یک مدل جدولی (Tabular model) ، یک رابطه فیزیکی دو جدول را از طریق یک معادل در یک ستون واحد به هم متصل می کند.

تحت شرایط خاصی که بعداً توضیح خواهیم داد، یک رابطه می تواند محدودیتی را برای محتوای جدول تعریف کند، حتی اگر چنین محدودیتی با «محدودیت کلید خارجی» که بسیاری از توسعه دهندگان SQL به آن عادت دارند، متفاوت باشد.

با این حال، هدف از رابطه در یک مدل جدولی، انتقال یک فیلتر در حین پرس و جو از مدل است.

مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

 

از آنجایی که انتقال فیلتر با نوشتن کد DAX نیز امکان پذیر است، دو دسته از روابط را تعریف می کنیم:

  • روابط مجازی: اینها روابطی هستند که در مدل داده تعریف نشده اند اما در مدل منطقی قابل توصیف هستند. روابط مجازی از طریق عبارات DAX پیاده سازی می شوند که زمینه فیلتر را از یک جدول به جدول دیگر منتقل می کنند. یک رابطه مجازی می‌تواند به بیش از یک ستون متکی باشد و می‌تواند به یک عبارت منطقی مرتبط باشد که فقط یک هویت ستون نیست. از روابط مجازی می توان برای تعریف روابط چند ستونی و روابط بر اساس یک محدوده استفاده کرد.
  • روابط فیزیکی: اینها روابطی هستند که در یک مدل جدولی تعریف شده اند. موتور به طور خودکار زمینه فیلتر را در یک پرس و جو با توجه به جهت فیلتر رابطه فعال منتشر می کند. روابط غیر فعال نادیده گرفته می شوند، اما توابع DAX وجود دارند که می توانند وضعیت و جهت فیلتر روابط فیزیکی را دستکاری کنند: USERELATIONSHIP و CROSSFILTER.

در این مقاله ابتدا روابط مجازی را نشان می دهیم. سپس انواع مختلف روابط فیزیکی را به تفصیل مورد بحث قرار می دهیم .

همچنین مفهوم روابط محدود را معرفی می کنیم. در نهایت، ما روابط چند به چند را معرفی می‌کنیم، انواع مختلف روابط چند به چند موجود در یک مدل و در Power BI را توصیف می‌کنیم,

بنابراین تفاوت‌های بین گزینه‌های موجود را روشن می‌کنیم و به طور خلاصه در مورد مفاهیم عملکرد بحث می‌کنیم.

روابط مجازی

یک رابطه مجازی فیلتری است که در یک تابع CALCULATE یا CALCULATETABLE به زمینه فیلتر اعمال می شود. برای انتشار فیلتر از A به B، باید مقادیر فعال در زمینه فیلتر را در A بخوانید و فیلتر مربوطه را به B اعمال کنید.

به عنوان مثال، تصور کنید که باید فیلتر را از مشتری به فروش منتقل کنید. بهترین راه برای انجام این کار استفاده از TREATAS است:

 

مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

 

تابع TREATAS همچنین می تواند یک رابطه منطقی بر اساس چندین ستون پیاده سازی کند. به عنوان مثال، کد زیر با استفاده از شماره سفارش و شماره خط سفارش، فیلتر را از یک جدول فروش به یک جدول تحویل منتقل می کند:

 

مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

 

توجه: ایجاد یک رابطه مجازی بر اساس چندین ستون از نقطه نظر عملکرد بهینه نیست. یک رابطه فیزیکی و تک ستونی مرتباً سریعتر از یک رابطه مجازی است.

از آنجایی که TREATAS یک عملکرد نسبتاً جدید است، تکنیک های رایج دیگری نیز برای پیاده سازی روابط مجازی مورد استفاده قرار می گیرد.

ما این گزینه ها را به عنوان مرجع درج می کنیم. به یاد داشته باشید که TREATAS روش ترجیحی برای ایجاد یک رابطه مجازی بر اساس معادل ستون است.

اولین تکنیک جایگزین استفاده از INTERSECT است:

 

مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

 

تکنیک جایگزین دوم استفاده از IN است:

 

مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

 

روش جایگزین دیگر استفاده از FILTER و CONTAINS است که قدیمی تر و کندتر از INTERSECT است:

 

مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

 

یک رابطه مجازی می تواند بر اساس یک محدوده باشد، مانند تکنیک مورد استفاده برای اجرای یک بخش بندی پویا:

 

مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

 

روابط فیزیکی

یک رابطه می تواند منظم یا محدود باشد. در یک رابطه منظم، موتور می داند که یک طرف رابطه حاوی مقادیر منحصر به فردی است.

اگر موتور نتواند بررسی کند که یک طرف رابطه دارای مقادیر منحصر به فرد برای کلید است، آنگاه رابطه محدود است. یک رابطه می تواند محدود شود یا به این دلیل که موتور نمی تواند منحصر به فرد بودن محدودیت را تضمین کند، به دلایل فنی که بعداً بیان می کنیم، یا به این دلیل که توسعه دهنده آن را به این صورت تعریف کرده است.

یک رابطه محدود به عنوان بخشی از گسترش جدول استفاده نمی شود.  Power BI از سال 2018 به مدل های کامپوزیت اجازه می دهد.

در یک مدل ترکیبی، امکان ایجاد جداول در یک مدل حاوی داده‌ها در هر دو حالت Import (یک کپی از داده‌ها از منبع داده از قبل بارگذاری شده و با استفاده از موتور VertiPaq در حافظه پنهان می‌شود) و در حالت DirectQuery (فقط منبع داده است) وجود دارد. در زمان پرس و جو قابل دسترسی است).

یک مدل داده واحد می تواند شامل جداول ذخیره شده در VertiPaq و جداول ذخیره شده در DirectQuery باشد. پ علاوه بر این، جداول در DirectQuery می‌توانند از منابع داده‌های مختلف سرچشمه گرفته و چندین جزیره داده DirectQuery را ایجاد کنند.

به منظور تمایز بین داده ها در VertiPaq و داده ها در DirectQuery، می گوییم که داده ها یا در قاره (VertiPaq) یا در جزایر (منابع داده DirectQuery) هستند.

 

 

برای مشاهده ویدیوی آموزشی Custom Tooltip in Power BI در یوتیوب لینک زیر را کلیک کنید

⇐ ⇐   Custom Tooltip in Power BI

آموزش Tooltip در Power BI

 

 

 

 

 

مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

 

فروشگاه VertiPaq چیزی نیست جز جزیره داده دیگری. ما آن را قاره می نامیم، زیرا پرکاربردترین جزیره داده است.

یک رابطه دو جدول را به هم پیوند می دهد. اگر هر دو جدول متعلق به یک جزیره باشند، رابطه یک رابطه درون جزیره ای است. اگر این دو جدول متعلق به جزایر مختلف باشد، پس این یک رابطه بین جزیره ای است.

روابط بین جزیره ای همیشه روابط محدودی هستند. بنابراین، گسترش جدول هرگز از جزایر عبور نمی کند. روابط دارای یک اصل است که سه نوع آن وجود دارد. تفاوت بین آنها هم فنی و هم معنایی است.

در اینجا ما استدلال پشت آن روابط را پوشش نمی دهیم زیرا شامل بسیاری از انحرافات مدل سازی داده می شود که خارج از محدوده این مقاله هستند. در عوض، ما باید جزئیات فنی روابط فیزیکی و تاثیری که بر روی کد DAX دارند را پوشش دهیم.

 

سه نوع اصلی رابطه :

  • روابط یک به چند(One-to-many relationships): این رایج‌ترین نوع رابطه میانی است. در یک طرف رابطه، ستون باید دارای مقادیر منحصر به فرد باشد.

در چند طرف، مقدار می تواند (و معمولاً) حاوی موارد تکراری باشد. برخی از ابزارهای مشتری بین روابط یک به چند و روابط چند به یک تفاوت قائل می شوند.

با این حال، آنها همان نوع رابطه هستند. همه چیز به ترتیب جداول بستگی دارد: رابطه یک به چند بین محصول و فروش مانند رابطه چند به یک بین فروش و محصول است.

  • روابط یک به یک(One-to-one relationships): این یک نوع نسبتاً غیر معمول از کاردینالیته رابطه است. در هر دو طرف رابطه، ستون ها باید مقادیر منحصر به فردی داشته باشند. نام دقیق‌تر رابطه «صفر یا یک» به «صفر یا یک» است زیرا وجود یک ردیف در یک جدول به معنای وجود سطر مربوطه در جدول دیگر نیست.
  • روابط چند به چند(Many-to-many relationships): در هر دو طرف رابطه، ستون ها می توانند تکراری باشند. این ویژگی در سال 2018 معرفی شد و متاسفانه نام آن تا حدودی گیج کننده است.

در واقع، در زبان مدل‌سازی داده‌های رایج، «چند به چند» به نوع متفاوتی از پیاده‌سازی اشاره دارد که با استفاده از جفت‌های یک به چند و چند به یک ایجاد می‌شود.

درک این نکته مهم است که در این سناریو خیلی به چند به رابطه خیلی به چند اشاره نمی کند، بلکه به اصل بودن رابطه خیلی به چند اشاره دارد.

 

مدل جدولی (Tabular model) در پاور بی ای - داده کاوی ویستا

 

دوره آموزشی هوش تجاری با Power BI »کلیک کنید« یک برنامه جامع است که بر توسعه مهارت در تجزیه‌ و تحلیل داده‌ها، تجسم و گزارش سازی و گزارش دهی و دشبوردسازی با استفاده از ابزار Power BI تمرکز دارد.

سپاسگذاریم از وقتی که برای خواندن این مقاله گذاشتید

.

برای خرید لایسنس نرم افزار Power BI کلیک کنید

.

برای مشاهده ویدیوهای آموزشی داده کاوی و هوش تجاری ما را در شبکه های اجتماعی دنبال کنید

Youtube Chanel :VISTA Data Mining کانال یوتیوب

Aparat Chanel: VISTA Data Mining کانال آپارات

Instagram Chanel: VISTA Data Mining کانال اینستاگرام

Telegram Chanel: VISTA Data Mining کانال تلگرام

Linkedin Chanel: VISTA Company کانال لینکدین

 

خرید دوره آموزشی پاور بی آی

امتیاز دهید

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

سبد خرید
ورود

هنوز حساب کاربری ندارید؟

خانه
0 محصول سبد خرید
0 علاقه مندی
حساب کاربری من