前提・実現したいこと
私は以下のリレーションモデルがあります。
BookUser(one) to Book(many).
で、Bookの一覧リストの機能を作りたい時にControllerでqueryを作り空いてるのBookを含めたリスト作って欲しいです、それで、ajaxでorderByなど内容を変えるとか実現したい。
でもいま出てる内容と実際にほしい内容が違います。借りていた本した出ていないのです、
public function index(BookIndexRequest $request) { $query = Book::select( 'books.*') ->john( 'bookUsers' , 'bookUsers.id' , '=', 'books.borrowing_user_id' ); if ($request->ajax()) { if ( !empty( $request->get('seachText') ) ) { $query->where('book.name', 'LIKE', '%'.$request->get('seachText').'%'); } if ( !empty( $request->get('orderBys') ) ) { foreach ($request->get('orderBys') as $key => $value) { $query->orderBy($key, $value); } } return \Response::json($query->get() ); } $books = $query->get(); return view('books.index', compact( 'books')); } /** query 内容 books.book_name | books.borrowing_user_id | bookUsers.name BookA | 1 | Tom BookC | 5 | Peter */
実際にほしい内容はこんな感じ
books.book_name | books.borrowing_user_id | bookUsers.name BookA | 1 | Tom BookB | Null | Null BookC | 5 | Peter BookD | Null | Null BookE | Null | Null BookF | Null | Null BookG | 11 | Ken
ほしい内容のqueryの作り方をご教授お願い致します。
該当のソースコード
BookUser model
php
1class BookUser extends Model 2{ 3 use SoftDeletes; 4 5 protected $fillable = [ 6 'name' 7 ,'created_at' 8 ,'updated_at' 9 ,'deleted_at' 10 ]; 11} 12 13public function books() 14{ 15 return $this->hasMany(Book::class, 'borrowing_user_id', 'id'); 16}
Book model
php
1class Book extends Model 2{ 3 use SoftDeletes; 4 5 protected $fillable = [ 6 'borrowing_user_id' //nullの時に空いてる 7 ,'book_name' 8 ,'created_at' 9 ,'updated_at' 10 ,'deleted_at' 11 ]; 12} 13 14public function borrowing_user() 15{ 16 return $this->belongsTo(User::class, 'borrowing_user_id', 'id'); 17}
補足情報(FW/ツールのバージョンなど)
Laravel 5.7
PHP 7.2
CentOS 7
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/12/05 07:20
退会済みユーザー
2019/12/05 07:43
退会済みユーザー
2019/12/05 07:50 編集