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

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

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

Frameworkは、アプリケーションソフトを開発する際に、一般的な機能をより簡単に、より早く完了させる事を目的とした、ソフトウェアやライブラリのセットを指します。開発にフレームワークを使用する事で、追加で必要となる機能だけを開発するだけで済む為、開発効率の向上が見込めます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

3回答

6673閲覧

LaravelでのSQL直書きについての質問です。

kaihotate

総合スコア1

Framework

Frameworkは、アプリケーションソフトを開発する際に、一般的な機能をより簡単に、より早く完了させる事を目的とした、ソフトウェアやライブラリのセットを指します。開発にフレームワークを使用する事で、追加で必要となる機能だけを開発するだけで済む為、開発効率の向上が見込めます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

0クリップ

投稿2021/09/14 14:13

Laravelについて、質問なのですが、現在Laravelを使って、システム開発を行なっています。
以前に、Fuel PHPを使ったことがありフレームワークには慣れてはいますが、
Laravelに関して疑問に思って、可能かどうか調べてもあまり出てこないのでこちらで質問させていただきます。

DBにPostgresSQLをつかっており、データを取ってくる際はクエリビルダを基本的には使ってデータを取っています。
where,join等、問題なく利用できており今まで困っていませんでしたが、
複雑なSQLがあり、SQL文を直書きする必要が出てきました。

その際に
①、SQL文を書く場所は Controllerでいいのか。
②、Fuel PHPではModelにSQLを書いて、Contorllerで必要な際に呼び出して、データを取ることができました。
(Moedelにget_date()というSQLが書かれたメソッドがある際は、Controllerでモデル::get_date()で使えてました)
Laravelでも、SQL文をモデルに記載して、それをコントローラーで呼び出すことはできるのでしょうか。もしくはモデル以外に記載して、呼び出すことができるのでしょうか。
③、②ができるとしたら、どのように記載を行えばいいのか、また引数を渡したい場合はどのようにしたらいいのか。

の以上3点を教えていただきたいです。
直接書きたいSQL文が、結構長くてこのままControllerに書いていると長くなりそうなのでそれを避けたいです。
現在はまだ規模が大きくないシステムなので、ServiceContorollerや、FormRequest、ユースケースはまだ使用していませんが、
後々面倒になりそうなので、それぞれ作成して製造を進めていくつもりです。

長くなりましたが、わかるかたがいらっしゃいましたら教えていただきたいです、
よろしくお願いいたします。

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

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

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

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

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

guest

回答3

0

基本Modelにデータベース検索、更新の処理を書いて下さい
サンプルで書き捨てならどこでもいいですが
コントローラに以下のように書くのが見られますが
MVCの考え方からは推奨できません

・他のコントローラにもwhere書きそうでDRYじゃない
・そもそもコントローラに処理をゴリゴリ書くものではない

php

1public function index(Request $request) 2{ 3 $users = User::where('name', 'like', '%'.$request->input('keyword').'%')->get(); 4}

なので、Model内に書くのが良いと思います
ただし、インジェクションには気をつけて下さい

投稿2021/09/28 11:20

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

kaihotate

2021/10/01 02:19

ありがとうございます。Model内に記載を行います。ありがとうございました。
guest

0

ベストアンサー

①、SQL文を書く場所は Controllerでいいのか。

Modelに書いたほうがいいと思います。

②、Fuel PHPではModelにSQLを書いて、Contorllerで必要な際に呼び出して、データを取ることができました。
(Moedelにget_date()というSQLが書かれたメソッドがある際は、Controllerでモデル::get_date()で使えてました)
Laravelでも、SQL文をモデルに記載して、それをコントローラーで呼び出すことはできるのでしょうか。もしくはモデル以外に記載して、呼び出すことができるのでしょうか。

Laravelは個人的にFuel PHPよりもユルく、大体どこに書いても呼び出せそうな雰囲気です。

③、②ができるとしたら、どのように記載を行えばいいのか、また引数を渡したい場合はどのようにしたらいいのか。

例えばUserモデルに、生SQLを使ったメソッドを追加する例を書いてみます。

  • app/User.php

php

1<?php 2 3namespace App; 4 5use Illuminate\Contracts\Auth\MustVerifyEmail; 6use Illuminate\Foundation\Auth\User as Authenticatable; 7use Illuminate\Support\Facades\DB; 8 9class User extends Authenticatable 10{ 11 ...省略 12 /** 13 * 現在のユーザで挨拶を返す 14 * @return array 15 */ 16 public function greeting() { 17 $sql = <<<SQL 18SELECT CONCAT('私の名前は、「',name,'」です') AS hello FROM users 19WHERE id = ? 20-- この先死ぬほど複雑予定 21SQL; 22 return DB::select($sql,[$this->id]); 23 } 24 /** 25 * みんなの挨拶を返す 26 * @return array 27 */ 28 public static function greetingAll() { 29 $sql = <<<SQL 30SELECT CONCAT('私の名前は、「',name,'」です') AS hello FROM users 31-- この先死ぬほど複雑予定 32SQL; 33 return DB::select($sql); 34 } 35}

コントローラに記載してもいいですが、今回は手っ取り早くroutesに直接かきます。

  • app/routes/web.php

php

1<?php 2...省略 3Route::get('/greeting/{id}',function ($id){ 4 return \App\User::find($id)->greeting(); 5}); 6Route::get('/greeting',function (){ 7 return \App\User::greetingAll(); 8});
  • ブラウザから/greeting/1にアクセスした結果

json

1[ 2 { 3 "hello": "私の名前は、「テスト 太郎」です" 4 } 5]
  • ブラウザから/greetingにアクセスした結果

json

1[ 2 { 3 "hello": "私の名前は、「テスト 太郎」です" 4 }, 5 { 6 "hello": "私の名前は、「テスト 花子」です" 7 } 8]

投稿2021/09/14 16:02

mj29

総合スコア136

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

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

kaihotate

2021/10/01 02:18

大変助かりました。参考にさせていただきます。ありがとうございました。
guest

0

ざっくりな答えになりますが、①②ともに良いといえば良いし、できるといえばできるでしょう。Laravelはフレームワークですが、どこにどの処理を書いてもそれで動けば問題ないという考えもあると思います。

ただ、保守性や可読性などを考慮すると、Fat ModelやFat Controllerになることは避けるのが無難です。Eloquentを使おうがクエリビルダを使おうが生SQLを使おうが、これは共通の認識になると思います。

これを避ける上でLaravelで一番定番なのはリポジトリパターンと呼ばれる手法だと思います。説明するとめちゃくちゃ長くなりますので、"Laravel リポジトリパターン"で検索してみてください。

参考)
https://qiita.com/karayok/items/d7740ab2bd0adbab2e06

ただ、むやみにリポジトリを分けたり複雑なクエリをリポジトリにまるっと委ねるとそれはそれで悪影響があるので、その辺は色んなサイトを見ながら学んでいってください。

参考)
https://qiita.com/mikesorae/items/ff8192fb9cf106262dbf

投稿2021/09/14 15:48

AbeTakashi

総合スコア4820

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

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

kaihotate

2021/10/01 02:18

参考サイトまで、ありがとうございます。解決できました。またお力添えお願いいたします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問