Heim > Backend-Entwicklung > PHP-Tutorial > laravel5 中 关联查询

laravel5 中 关联查询

WBOY
Freigeben: 2016-06-06 20:33:30
Original
1479 Leute haben es durchsucht

有这么一组数据

一个学生表users 和 学生成绩表 grades 两个表关联

在方法里面是这样的

<code>public function index()
{
    $result = User::where('is_admin', 0);
    $users = $result->get();
    $count = $result->count();       
    return view('admin.list', compact('count', 'users'));
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

视图循环是这样的

<code> @foreach ($users as $user)
    <tr>
        <td>{{$user->id}}</td>
        <td>{{$user->name}}</td>
        <td>{{$user->grade->math}}</td>
        <td>{{$user->grade->english}}</td>
        <td>{{$user->grade->c}}</td>
        <td>{{$user->grade->sport}}</td>
        <td>{{$user->grade->think}}</td>
        <td>{{$user->grade->soft}}</td>
    </tr>
@endforeach
</code>
Nach dem Login kopieren
Nach dem Login kopieren

得到的结果是 报错 Trying to get property of non-object (View:

<code>$user->grade->math
</code>
Nach dem Login kopieren
Nach dem Login kopieren

是找不到的 怎么做关联一起呢

回复内容:

有这么一组数据

一个学生表users 和 学生成绩表 grades 两个表关联

在方法里面是这样的

<code>public function index()
{
    $result = User::where('is_admin', 0);
    $users = $result->get();
    $count = $result->count();       
    return view('admin.list', compact('count', 'users'));
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

视图循环是这样的

<code> @foreach ($users as $user)
    <tr>
        <td>{{$user->id}}</td>
        <td>{{$user->name}}</td>
        <td>{{$user->grade->math}}</td>
        <td>{{$user->grade->english}}</td>
        <td>{{$user->grade->c}}</td>
        <td>{{$user->grade->sport}}</td>
        <td>{{$user->grade->think}}</td>
        <td>{{$user->grade->soft}}</td>
    </tr>
@endforeach
</code>
Nach dem Login kopieren
Nach dem Login kopieren

得到的结果是 报错 Trying to get property of non-object (View:

<code>$user->grade->math
</code>
Nach dem Login kopieren
Nach dem Login kopieren

是找不到的 怎么做关联一起呢

User.php

<code>public function grade()
    {
        return $this->hasOne('App\Grade');
    }
</code>
Nach dem Login kopieren

Grade.php

<code>public function user()
    {
        return $this->belongsTo('App\User');
    }
</code>
Nach dem Login kopieren

<code>php</code><code>User.php定义
public function Grade()
    {
        return $this->hasOne("App\Modules\Grade", 'user_id', 'id');
    }
controller.php
public function index()
{
    $result = User::where('is_admin', 0);
    $users = $result->grade()->get();
    $count = $result->count();       
    return view('admin.list', compact('count', 'users'));
}

view:
@foreach ($users as $user)
    <tr>
        <td>{{$user->id}}</td>
        <td>{{$user->name}}</td>
        <td>{{$user->math}}</td>
        <td>{{$user->english}}</td>
        <td>{{$user->c}}</td>
        <td>{{$user->sport}}</td>
        <td>{{$user->think}}</td>
        <td>{{$user->soft}}</td>
    </tr>
@endforeach

</code>
Nach dem Login kopieren
Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage