【问题标题】:Find auctions for a user in eloquent在 eloquent 中为用户查找拍卖
【发布时间】:2015-08-08 18:26:17
【问题描述】:

我正在使用 L5 和 elequent
我的表结构是..
users
身份证
其他领域
拍卖
身份证
其他字段
很多
身份证
拍卖ID
其他字段
lot_user
批号
用户ID
我想为用户查找拍卖。
我该怎么做?

$user = User::find($id);
$auctions = $user->auctions();

【问题讨论】:

    标签: php laravel laravel-4 laravel-5


    【解决方案1】:

    我有个想法用 eloquent 来做这件事。

        $auctions = $user->lots()
        ->join('auctions','auctions.id','=','lots.id')
        ->select(['auctions.*'])
        ->get();
    

    【讨论】:

      【解决方案2】:

      我不确定 Eloquent 在这里是否会非常高效,但您可以执行以下操作:

      在您的 User(s) 类中,您需要定义多对多关系,例如:

      public function lots()
      {
          return $this->belongsToMany('App\Lot');
      }
      

      在您的 Lot(s) 类中,您需要定义一对多关系的逆向,例如:

      public function auctions()
      {
          return $this->belongsTo('App\Auction')
      }
      

      然后,要为用户获得很多,您需要执行以下操作:

      $user->lots();
      

      要获得拍卖,您需要遍历批次并为每个批次调用 $lot->auctions(),然后按 id 过滤以获得唯一的拍卖。

      在这种情况下,使用 DB 外观构建查询可能比仅仅尝试使用 Eloquent 更容易。

      【讨论】:

      • 拍卖没有 user_id 列
      【解决方案3】:

      关于 DB 门面。 原始查询将如下所示:

      SELECT * FROM auctions AS a
      INNER JOIN lots AS l ON (l.auction_id = a.id)
      INNER JOIN lot_user AS lu ON (lu.lot_id = l.id AND lu.user_id = $findUserId)
      GROUP BY a.id
      

      使用查询构建器,您可以这样做:

      DB::table('auctions')
          ->join('lots', 'lots.auction_id', '=', 'auctions.id')
          ->join('lot_user', function ($join) {
              $join->on('lot_user.lot_id', '=', 'lots.id')
                  ->where('lot_user.user_id', '=', $findUserId);
          })
          ->groupBy('auctions.id')
          ->get();
      

      【讨论】:

        猜你喜欢
        • 2022-01-05
        • 1970-01-01
        • 2023-03-15
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2018-11-11
        • 2014-11-27
        • 2016-02-19
        相关资源
        最近更新 更多