Как получить значение из третьей таблицы в laravel и упорядочить по id в порядке убывания - PullRequest
0 голосов
/ 23 мая 2018

В контроллере у меня есть код, подобный этому:

public function index(Request $request)
    {
        $course=Student::with('StudentDetail')->get();
        $courses=$course->toArray();
        echo "<pre>";print_r($courses);exit;
        return view('student.student_listing',['result'=>$courses]);

    }

благодаря этому я получаю результат, как:

Array
(
    [0] => Array
        (
            [id] => 1
            [name] => Neha
            [email] => neha@sob.com
            [roll_no] => 101
            [created_at] => 2018-05-22 09:20:18
            [updated_at] => 2018-05-22 00:00:00
            [student_detail] => Array
                (
                    [id] => 1
                    [student_id] => 1
                    [phone] => 11691110876
                    [course] => Java
                    [city] => Goa
                    [state] => 1
                    [created_at] => 2018-05-22 16:48:36
                    [updated_at] => 2018-05-22 09:20:43
                )

        )

    [1] => Array
        (
            [id] => 2
            [name] => Ankit
            [email] => Ankit@sbo.com
            [roll_no] => 102
            [created_at] => 2018-05-22 09:20:18
            [updated_at] => 2018-05-22 00:00:00
            [student_detail] => Array
                (
                    [id] => 2
                    [student_id] => 2
                    [phone] => 12313311
                    [course] => Phps
                    [city] => Delhi
                    [state] => 2
                    [created_at] => 2018-05-23 13:28:19
                    [updated_at] => 2018-05-15 03:15:13
                )

        )

)

Здесь я получаю состояние поля, где яя получаю идентификатор, этот идентификатор связан с идентификатором таблицы состояний, как я могу получить значение из таблицы состояний на основе этого идентификатора, и я хочу получить этот результат в порядке убывания с именем или идентификатором, как я могу это сделать, может кто-нибудь, пожалуйста, помогите мне с этим.

модели, которые мне нравятся:

StudentDetail Model:
<?php

namespace App\Http\Model;

use Illuminate\Database\Eloquent\Model;
use App\Http\Model\Student;
use App\Http\Model\State;
class StudentDetail extends Model
{ 
    public function Student()
    {
         return $this->belongsTo(Student::class);

    }
  public function state()
    {
         return $this->hasOne(State::class);

    }

}



Student model:
<?php

namespace App\Http\Model;

use Illuminate\Database\Eloquent\Model;
use App\Http\Model\StudentDetail;

class Student extends Model
{ 
     public function StudentDetail()
    {
        return $this->hasOne(StudentDetail::class);
    }

}

1 Ответ

0 голосов
/ 23 мая 2018

Вы можете использовать вложенные with()

public function index(Request $request)
    {
        $course=Student::with(['StudentDetail' => function($query){

           $query->with('state);
}])->get();
        $courses=$course->orderBy('studentDetail.state');
        echo "<pre>";print_r($courses);exit;
        return view('student.student_listing',['result'=>$courses]);

    }

Или вы можете просто использовать.

public function index(Request $request)
    {
        $course=Student::with('StudentDetail.state')->get();;
        $courses=$course->orderBy('studentDetail.state');;
        echo "<pre>";print_r($courses);exit;
        return view('student.student_listing',['result'=>$courses]);

    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...