teratail header banner
teratail header banner
質問するログイン新規登録
CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

992閲覧

CakePHP3 SQLを直入力するときの変数の使用方法

dikky

総合スコア13

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

0クリップ

投稿2019/02/21 05:49

0

0

ControllerでSQLを直打ちしたいのですが、
変数を使用したいのですが、うまくいきません。
どうすれば変数を埋め込めるのでしょうか?

PHP

1コード``` 2SELECT distinct(meigara_code) 3 FROM y 4 WHERE 5 meigara_name = $meigara_name

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

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

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

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

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

m.ts10806

2019/02/21 06:04

ちなみに「うまくいきません。」では実際に何をしてうまくいってないのか分かりません。 丸投げですので、私の回答を見る前にきちんと質問を編集して追記してください。
guest

回答1

0

ベストアンサー

マニュアルを読みこみましょう。
直に実行する手段はあるようですよ。

SQLに変数を使いたい?
SQLといえど単なる文字列です。文字列結合なり文字列の中に変数を埋め込むなりはPHPで基本です。
ただ、プリペアドステートメントで実行してくださいね。本当にそのまま使うと文字列が入っているならSQL構文エラーとなりますし、SQLインジェクションの脅威にさらされます。

パラメーターを追加するには、プリペアードステートメントを使います。
$results = $connection
->execute('SELECT * FROM articles WHERE id = :id', ['id' => 1])
->fetchAll('assoc');

ただ、distinctあるのでそちらを使ったほうが良いのでは・・。

投稿2019/02/21 06:02

m.ts10806

総合スコア80888

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

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

dikky

2019/02/21 06:56

ありがとうございました。できました。 クエリビルダーを調べて実行したほうがシンプルでした。
m.ts10806

2019/02/21 07:06

回答の後半にある通りですね。 フレームワークとはいえ、柔軟に対応ができるはずなので、マニュアル読み込みが基本です。 (ただこの内容レベルの質問が続くと回答つかなくなります。なるべく質問テンプレートを使って書きましょう)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問