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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Eloquent

Eloquentとは、PHPフレームワークのLaravelに最初から含まれているORM(Object-relational mapping:オブジェクト関係マッピング)です。

Q&A

解決済

1回答

5853閲覧

(PHP) LaravelのEloquentでデータが取得できない

hwudkps

総合スコア26

Eloquent

Eloquentとは、PHPフレームワークのLaravelに最初から含まれているORM(Object-relational mapping:オブジェクト関係マッピング)です。

0グッド

0クリップ

投稿2014/12/07 07:16

PHP、Laravelとも初心者です。どうぞ宜しくお願いいたします。
LaravelのEloquentでデータを取得する部分を書いています。

lang

1 $chairs = Chair::where('height','>','50')->get();

上記のコードは正常に動作します。
しかし、where()の中を変数にすると

lang

1 $str = "'height','>','50'"; 2 $chairs = Chair::where($str)->get();

次のようなエラーになります。

lang

1SQLSTATE[42S22]: Column not found: 1054 Unknown column ''height','>','50'' in 'where clause' (SQL: select * from `chairs` where `'height','>','50'` is null) 2

これは解決できないでしょうか?
whereの内容を可変にしたいので、変数で操作したいのですが・・・。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

詳細は下記をご覧いただくとして
http://laravel4.kore1server.com/docs/queries#advanced-wheres
http://laravel4.kore1server.com/api/class-Illuminate.Database.Query.Builder.html

where()の最初の引数はカラム名、2番目の引数は演算子(null許可)、
3番目の引数は値(null許可)、4番目の引数は論理値(デフォルト値'and')です。

そのコードの書き方だと、文字数の引数を1つだけしか渡していないことになります。
以下のようにすれば動作するはずです。

lang

1$str1 = 'height'; 2$str2 = '>'; 3$str3 = '50'; 4$chairs = Chair::where($str1,$str2,$str3)->get();

投稿2014/12/07 12:51

skytreebutrainy

総合スコア65

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問