Heim > Backend-Entwicklung > PHP-Tutorial > laravel Eloquent ORM – Relevanz

laravel Eloquent ORM – Relevanz

WBOY
Freigeben: 2016-10-11 14:23:37
Original
1232 Leute haben es durchsucht

Tabellenstruktur

<code>posts
    id - integer
    title - string
    body - text

comments
    id - integer
    post_id - integer
    user_id - integer
    body - text
users
    id - integer
    name - string
    phone - integer
    sex - integer
    
comment_likes
    id - integer
    comment_id - integer
    user_id - integer</code>
Nach dem Login kopieren
Nach dem Login kopieren

Verwenden Sie laravel Eloquent ORM

<code><?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Posts extends Model
{
     /**
     * @var string
     */
    protected $table = 'posts';

    public function comments()
    {
        return $this->belongsTo('App\Comments', 'post_id', 'id');
    }
}</code>
Nach dem Login kopieren
Nach dem Login kopieren

Ich hoffe, dass wir bei der Abfrage der Nachrichteninformationen von posts alle Informationencomments von user_id über userss

abfragen können

Antwortinhalt:

Tabellenstruktur

<code>posts
    id - integer
    title - string
    body - text

comments
    id - integer
    post_id - integer
    user_id - integer
    body - text
users
    id - integer
    name - string
    phone - integer
    sex - integer
    
comment_likes
    id - integer
    comment_id - integer
    user_id - integer</code>
Nach dem Login kopieren
Nach dem Login kopieren

Verwenden Sie laravel Eloquent ORM

<code><?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Posts extends Model
{
     /**
     * @var string
     */
    protected $table = 'posts';

    public function comments()
    {
        return $this->belongsTo('App\Comments', 'post_id', 'id');
    }
}</code>
Nach dem Login kopieren
Nach dem Login kopieren

Ich hoffe, dass wir bei der Abfrage der Nachrichteninformationen von posts alle Informationencomments von user_id über userss

abfragen können

Comment.php

<code>class Comment extends Model {
    public function user () {
        return $this->hasOne('App\User', 'id', 'user_id');
    }
}</code>
Nach dem Login kopieren

Beim Lesen mit

<code>$posts = Post::where(....)->with(['comments' => function($query) {
    $query->with('user');
}])->get();

foreach($posts $post)
    foreach($post->comments as $comment)
        echo $comments->user->name;</code>
Nach dem Login kopieren

Normalerweise geschieht dies durch die Verwendung von „spart Leistung“,


Wenn Ihnen die Leistung egal ist, können Sie es wie folgt tun. Aber ich gebe dir 0 Punkte. Lernen Sie nicht aus Folgendem

<code>$posts = Post::find(1);
foreach ($posts->comments as $comment)
    echo $comment->user->name;</code>
Nach dem Login kopieren

Warum? Schauen Sie sich den Unterschied bei der Verwendung von mit im ORM-Tutorial an, das ich geschrieben habe
http://www.load-page.com/base...

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