dt2015 2014-06-03 22:13
浏览 8
已采纳

Laravel 4多人同桌

I have a laravel 4 application and in this application I need to define a model with relation to another model 2 times but with discrimination on type.

Example

class Car extends Eloquent{

     public function oldDrivers(){
        return $this->hasMany('Driver');
     }

     public function newDrivers(){
        return $this->hasMany('Driver');
     }

}

so the relation will be the car Id at the driver's table, the thing is when I want to get the old drivers only for a certain car, it returns all drivers from both relations.

When looking into it I found because it is the same table, so now I set a type in the Driver model, now I want my relation to be filtered by this type, so the oldDrivers will be only drivers with the type of oldDrivers and new drivers will be the Drivers with only the newDriver type set,

How can this be done in Laravel ?

  • 写回答

1条回答 默认 最新

  • douan9541 2014-06-03 22:20
    关注

    You may try something like this:

    class Car extends Eloquent{
    
         public function oldDrivers(){
            return $this->hasMany('Driver')->where('type', 'olddrivers');
         }
    
         public function newDrivers(){
            return $this->hasMany('Driver')->where('type', 'newdrivers');
         }
    
     }
    

    Assumed that you have type field as a filter in your database. If I'm wrong about type field then you just change the field name to the right one because you got the idea that how can you add filter using a where clause.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案
  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了
  • ¥100 H5网页如何调用微信扫一扫功能?
  • ¥15 讲解电路图,付费求解
  • ¥15 有偿请教计算电磁学的问题涉及到空间中时域UTD和FDTD算法结合的
  • ¥15 three.js添加后处理以后模型锯齿化严重