K@m@l نشر 19 يناير 2016 أرسل تقرير نشر 19 يناير 2016 لدي البنية التالية على تطبيق مبني على إطار العمل Laravel، حيث تربط علاقة بين جدولين، بالشكل التالي:User - id - other stuff NeighborhoodFilter - id - userId - neighborhoodId - isActive Neighborhood - id - other stuffأريد إنشاء وظيفة methode خاصة بـ user للحصول على جميع nighbhood الذين تربطهم به علاقة، وهذه هي محاولتي:public function neighborhoods() { return $this->hasManyThrough('Neighborhood', 'NeighborhoodFilter', 'userId', 'id'); }لكن لا أعلم كيف أجعل حملة الاستعلام تعتمد على isActive=1؟ اقتباس
0 E.Nourddine نشر 21 يناير 2016 أرسل تقرير نشر 21 يناير 2016 توفّر Laravel خاصية الربط whereHas في حال احتجنا التأكد من توفر الجدول المرتبط به -مع جدول آخر- على قيمة معينة.وفي حالتنا هذه حيث يوجد رابط بين Neighborhood وَNeighborhoodFilter، من Neighborhood يمكننا كتابة:public function neighborhoods() { return $this->hasManyThrough('Neighborhood', 'NeighborhoodFilter', 'userId', 'id')->whereHas('neighborhoodFilters', function($q){ $q->where('isActive', 1); }); } أو يمكنك استعمال رابطة belongsToMany وَ wherePivot:public function neighborhoods() { return $this->belongsToMany('Neighborhood', 'neighborhood_filters', 'user_id', 'neighbor_id')->wherePivot('isActive', 1); }laravel 5.2 relationships اقتباس
السؤال
K@m@l
لدي البنية التالية على تطبيق مبني على إطار العمل Laravel، حيث تربط علاقة بين جدولين، بالشكل التالي:
أريد إنشاء وظيفة methode خاصة بـ user للحصول على جميع nighbhood الذين تربطهم به علاقة، وهذه هي محاولتي:
لكن لا أعلم كيف أجعل حملة الاستعلام تعتمد على isActive=1؟
1 جواب على هذا السؤال
Recommended Posts
انضم إلى النقاش
يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.