اذهب إلى المحتوى

السؤال

نشر

أحاول تصفية النتائج من جدول lands بعد تحميل العلاقات  stage  و project معه, 

Land --> Has One --> Stage
Land --> Has One --> Project
$availableLands = Land::with('stage', 'project');

dd($availableLands->stage->name); // works and returns (STAGE_NAME)
dd($availableLands->project->name); // works and returns (PROJECT_NAME)

ولكن عندما أصل إلى الحقول باستخدام where ، يظهر خطأ:

$availableLands = Land::with('stage', 'project');

$results = $availableLands->where('stage.name', 'ilike', '%'. $this->search . '%')->
orWhere('project.name', 'ilike', '%'. $this->search . '%')->
orWhere('lands.land_id', 'like', '%'. $this->search . '%')->
paginate(15);

الخطأ

SQLSTATE[42P01]: Undefined table: 7 ERROR: missing FROM-clause entry for table "stage"... 

هل يمكنكم المساعدة؟

Recommended Posts

  • 0
نشر

يوفر Laravel دوال خاصة لإجراء الشروط على العلاقات مثلا whereHas ,whereRelation, doesntHave, whereDoesntHave

فمثلا في حالة الكود الذي كتبته يمكنك اعادة كتابته كالتالي

<?php
$availableLands = Land::whereRelation('stage', 'name', 'like', "%".$this->search."%")->get();
?>

هنا تم استخدام دالة whereRelation وهي شكل مختصر في الاصدارات الحديثة من لارافل لاجراء الشروط على العلاقات

وتأخذ متغيراتها كالآتي:

1- اسم العلاقة

2- اسم الحقل في قاعدة البيانات

3- الإجراء (=, >, < , like, ) الخ

4- القيمة التي يقارن بها الحقل

انضم إلى النقاش

يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.

زائر
أجب على هذا السؤال...

×   لقد أضفت محتوى بخط أو تنسيق مختلف.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   جرى استعادة المحتوى السابق..   امسح المحرر

×   You cannot paste images directly. Upload or insert images from URL.

  • إعلانات

  • تابعنا على



×
×
  • أضف...