首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >调用未定义方法Illuminate\Database\Query\Builder::exchanges()

调用未定义方法Illuminate\Database\Query\Builder::exchanges()
EN

Stack Overflow用户
提问于 2018-06-04 07:24:15
回答 1查看 336关注 0票数 0

错误:第2435行中的 BadMethodCallException :调用未定义的方法BadMethodCallException

有两个表,名为EXCHANGES表和FINALTRADES表。

exchange_id有START_TIME字段(格式: 00:00:00),终结表有exchange_id。

我只想从最终交易表中计算start_time到start_time+1hrs之间的条目。例如:如果start_time有09:15:00,那么只计算09:15到10:15之间的记录。

功能:

代码语言:javascript
复制
public function getCountHour() {
       $user_id = Auth::user()->id;
       $countTrades = FinalTrade::where('user_id', '=', $user_id)
            ->exchanges()
            ->where('start_time', '>=', $your_desired_time)
            ->where('start_time' , '<=' , strtotime($your_desired_time) + 60*60)
            ->count();

                return response()->json($countTrades);

    }

给出FnalTrade模型的关系:

代码语言:javascript
复制
   public function exchanges(){
   return $this->hasOne('App\EXCHANGE_MODEL_NAME', 'id', 'exchange_id');
}

双屏

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-04 07:50:55

以下是其中的诀窍:

代码语言:javascript
复制
$countTrades = FinalTrade::whereUserId(Auth::id())
  ->whereHas('exchanges', function($query) use ($your_desired_time) {
    $query
      ->where('start_time', '>=', $your_desired_time)
      ->where('start_time' , '<=' , strtotime($your_desired_time) + 60*60);
})
->count();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50675293

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档