質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.72%

クエリースコープを使って、生SQLを使ったときのようにレコードを習得したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 916

chibi144

score 60

 前提・実現したいこと

namespaceとclassの理解が怪しい程度の初学者です。

inputに文字列を入力
→完全一致か前方一致か選択
→submit
→次のページで結果を表示

この流れをLaravelで実現したいと考えています。

見よう見まねでクエリースコープを使ってみたのですが、
getやfirstで取得できる配列が下のようになります。

完全一致でprint_r($items_arr)をした結果

App\Models\search Object
(
    [table:protected] => item
    [primaryKey:protected] => id
    [connection:protected] => mysql
    [keyType:protected] => int
    [incrementing] => 1
    [with:protected] => Array
        (
        )

    [withCount:protected] => Array
        (
        )

    [perPage:protected] => 15
    [exists] => 1
    [wasRecentlyCreated] => 
    [attributes:protected] => Array
        (
            [id] => xxx //期待どおりの値は習得できています
            [name] => xxxxx
        )
  ......(続く)
)

これを↓のように取得できないでしょうか。

Array
(
    [0] => Array
        (
            [id] => xxx
            [0] => xxx
            [name] => xxxx
            [1] => xxxx
        )

    [1] => Array
    (
            [id] => xxx
            [0] => xxx
            [name] => xxxx
            [1] => xxxx
        )
)

なぜ$items_arrにオブジェクトが入っているのか見当がつきません。
DB::table('item')を入れていないからなのかとも思いましたが、
どのタイミングで指定すればいいのかわかりません。
protected $table = 'item';で指定したのは何なんだろう…とも思ってしまいます。

 該当のソースコード

index.twig

<div>
  <form action="list" method="post">
    {{ csrf_field() }}
    <input type="text" name="input">
    <select name="search_type">
        <option value="perfect" selected>完全一致</option>
        <option value="fuzzy">を含む</option>
    </select>
    <button type="submit">検索</button>
  </form>
</div>

app/Models/search.php

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;

class search extends Model
{
    protected $table = 'item';
    protected $primaryKey = 'id';

    //完全一致
    public function scopePerfect($query, $input)
    {
        return $query->where('id', $input);
    }

    //前方一致
    public function scopeFuzzy($query, $input)
    {
        return $query->where('id', 'like', "$input%");
    }
}

listController.php

<?php

namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Models\search;

class listController extends Controller
{
    public function store(Request $request)
    {
        //リクエスト内容
        $conditions = $request;

        $md = new search();
        switch($request->search_type){
            case 'perfect':
                $items_arr = $md->Perfect($request->input)->first();
                break;
            case 'fuzzy':
                $items_arr = $md->fuzzy($request->input)->get();
                break;
            default:
                break;
        }
        echo '<pre>';
        print_r($items_arr);
        echo '</pre>';

        return view('list/list',
          compact( 'items_arr', 'conditions' )
        );
    }
}

 補足情報(FW/ツールのバージョンなど)

Laravel 5.6.3
PHP 7.1.8

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

コレクションの結果を配列としたい場合は、toArray()メソッドを使って下さい

$md->fuzzy($request->input)->first()->toArray()
$md->fuzzy($request->input)->get()->toArray()


Laravel 5.5 コレクション

これを↓のように取得できないでしょうか。

この例にある、数字添字の配列とキーによる連想配列が入り交じるものは特殊な形式なので、必要な場合は自身でさらに配列を加工して作成して下さい。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/02/16 18:43

    ご回答ありがとうございます。
    望んでいたまんまです!
    ドキュメントに載っていたんですね。勉強不足でした。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.72%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる