duanbarong4321 2016-09-14 16:42
浏览 25
已采纳

完善我的雄辩查询(Laravel)

Edited for Clarity:

I need some way for this Query to only return distinct course_ids in the

->wherein('course_id', $array)

part of the query. It gets the total number of completed courses, but if a user has completed a course more than once it counts it toward the total. So if you want to know how many students have done a course, the number will be off if a student has completed a course more than once.

    public function report_count(){
    $array = \Session::get('course_report')['course'];
    return $this->hasOne('Tracking', 'roster_id')
        ->selectRaw('roster_id, count(*) as aggregate')
        ->where('status', 1)
        ->wherein('course_id', $array)
        ->groupBy('roster_id');

I've tried adding groupBy('course_id') at the end but it does not work.

  • 写回答

1条回答 默认 最新

  • douhao2856 2016-09-15 13:57
    关注

    Fixed. Changed the query to

    return $this->hasOne('Tracking', 'roster_id')
            ->selectRaw('roster_id, count(distinct course_id) as aggregate')
            ->where('status', 1)
            ->wherein('course_id', $array)
            ->groupBy('roster_id');
    

    per @Robin R suggestion, I went on a search of ways to utilize SQL in my selectRaw query instead of trying this the eloquent way. Thanks to all who helped me brainstorm though this one.

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

报告相同问题?

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度