• 1403/06/24

ایجاد روابط polymorphic در پایگاه داده :

با سلام و درود

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

کلا برای اینگونه موارد که عمدتاً هم در پروژه ها با آنها برخورد داریم باید از چه روشی استفاده کرد؟

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

1- locations با plants روابط چند به چند

2- locations با researchers روابط چند به چند

3- samples با researchers روابط چند به چند

4- plants  با researchers روابط چند به چند

5- pests با researchers روابط چند به چند

6- pests با plants روابط چند به چند

7- pests با locations روابط چند به چند

8- locations با references روابط چند به چند

9- researchers با references روابط چند به چند

10- pests با samples روابط چند به چند

  • 1403/06/24
  • ساعت 16:33

سلام وقت بخیر

 

در مورد سؤال شما دربارهٔ انتخاب بین استفاده از جداول میانی (Pivot Tables) و روابط چندشکلی (Polymorphic Relations) در لاراول برای پیاده‌سازی روابط چند به چند بین جداول مختلف : 

 

 تفاوت بین Pivot Table و روابط Polymorphic در لاراول

 

Pivot Table (جدول میانی):

 

- زمانی استفاده می‌شود که دو مدل (جدول) یک رابطهٔ چند به چند معمولی با یکدیگر دارند.

- یک جدول واسط ایجاد می‌کنید که کلیدهای خارجی هر دو جدول را نگه می‌دارد.

- این روش ساده و مستقیم برای پیاده‌سازی روابط چند به چند بین دو مدل است.

 

Polymorphic Relations (روابط چندشکلی):

 

- زمانی استفاده می‌شود که یک مدل بتواند به چند مدل دیگر مرتبط باشد، بدون نیاز به ایجاد جداول میانی متعدد.

- به عنوان مثال، مدل Comment می‌تواند به مدل‌های Post، Video، یا Photo مرتبط باشد.

- این روش انعطاف‌پذیر است اما پیچیدگی بیشتری دارد و برای سناریوهای خاص مناسب است.

 

 برای پروژهٔ شما

 

با توجه به روابطی که ذکر کرده‌اید، تمامی روابط چند به چند بین **دو مدل مشخص** هستند. بنابراین، بهترین و ساده‌ترین روش استفاده از **Pivot Tables** است.

 

### نحوهٔ پیاده‌سازی روابط با Pivot Tables در لاراول

 

1. ایجاد جداول اصلی:

 

  ابتدا جداول اصلی خود را ایجاد کنید: `locations`، `plants`، `researchers`، `samples`، `pests`، `references`.

 

2. ایجاد جداول میانی (Pivot Tables):

 

  برای هر رابطهٔ چند به چند، یک جدول میانی ایجاد کنید. نام جدول می‌تواند ترکیبی از نام دو جدول اصلی باشد، معمولاً به صورت حروف کوچک و به ترتیب حروف الفبا. برای مثال:

 

  - `location_plant` برای رابطهٔ بین `locations` و `plants`.

  - `location_researcher` برای رابطهٔ بین `locations` و `researchers`.

  - و به همین ترتیب برای سایر روابط.

 

3. تعریف روابط در مدل‌ها:

 

  این کار را برای تمامی مدل‌ها و روابط انجام دهید.

 

5. استفاده از روابط در کد:

 

 


  • 1403/06/26
  • ساعت 09:10

با سلام و درود

ممنون از پاسخ جامع شما

پس با این حساب آیا این برداشت بنده درست است؟ که اگر مثلاً جدول X با جداول Y و Z رابطه داشته و در مقابل جداول Y و Z هم با هم رابطه داشته باشند، دیگر نمی توان از روش polymorphic   استفاده نمود

و باید از همان روش‌های روابط یک به یک، یک به چند یا چند به چند معمولی استفاده کرد؟

 


  • 1403/06/26
  • ساعت 14:01

سلام مجدد وقت شما بخیر

 

 

زنده باشید

 

 

بله، برداشت شما درست است. زمانی که جدول X با جداول Y و Z رابطه دارد، و همچنین جداول Y و Z نیز با یکدیگر رابطه دارند، استفاده از روابط چندشکلی (Polymorphic Relations) مناسب نیست.

• برای پیاده‌سازی روابط بین جداول X، Y و Z که هر کدام با یکدیگر روابط دارند، باید از روابط یک به یک، یک به چند یا چند به چند معمولی استفاده کنید.

• با استفاده از جداول میانی (Pivot Tables) برای روابط چند به چند، می‌توانید به سادگی و با انعطاف‌پذیری بیشتری روابط بین جداول را مدیریت کنید.

 

روابط چندشکلی برای مواردی مناسب هستند که یک مدل نیاز دارد به چندین مدل دیگر از نوع‌های مختلف مرتبط باشد، اما آن مدل‌ها با یکدیگر رابطه‌ای ندارند.

• در مواردی که چندین جدول با یکدیگر روابط چند به چند دارند، استفاده از روابط معمولی و جداول میانی بهترین و مناسب‌ترین روش است.

 


logo-samandehi