Laravelで生のSQLクエリを実行する方法は?
Laravelで生のSQLクエリを実行する主な方法は3つあります。最初に、DB ::選択メソッドを使用して元のクエリを実行し、SQL文字列を渡してパラメーター配列をバインドしてSQLインジェクションを防ぎ、結果のオブジェクトアレイを返します。次に、DB :: Statement()を使用して、挿入、更新、または削除操作を実行します。最後に、db :: raw()を使用して、複雑なクエリまたは集約ロジックに適した雄弁なクエリに生のSQLスニペットを埋め込みますが、保守性を維持するために過剰使用を避ける必要があります。常にパラメーターバインディングを使用してセキュリティを確保し、必要に応じて生のSQL(複雑なクエリ、パフォーマンスの最適化、レガシーデータベースなど)を使用して、特定のデータベースエンジンへの依存を減らします。
Laravelでは、Eloquent ORMはほとんどのデータベースインタラクションのための頼りになるツールですが、RAW SQLクエリを実行するだけである場合があります。パフォーマンス、複雑さ、利便性のいずれであっても、Laravelはそれを非常に簡単にします。

それを正しく行う方法は次のとおりです。
DB::select
生のSQLクエリを実行する最も簡単な方法は、 DB::select
メソッドを使用することです。 Laravelのデータベース接続の取り扱いと結果の水分補給の恩恵を受けながら、プレーンSQLを作成できます。

Illuminate \ support \ facades \ dbを使用します。 $ results = db :: select( 'select * from users Where Active =?'、[1]);
- 最初の引数はSQL文字列です。
- 2つ目はバインディングの配列です。これは、SQL注射を防ぐのに役立ちます。
- PHPオブジェクトの配列を返すため、それらをループしたり、フィールドに直接アクセスしたりできます。
データを選択していないが、挿入、更新、または削除を実行している場合は、代わりにDB::statement()
を使用してください。
バインディングパラメーターは正しい方法で
生のクエリを書くときは、値を直接SQL文字列に直接連結するのではなく、常にパラメーターバインディングを使用してください。これにより、SQL注入の脆弱性が回避されます。

たとえば、これを行う方法は次のとおりです。
$ userid = 5; $ results = db :: select( 'select * from Orders Where User_id =?'、[$ userId]);
または、名前のバインディングを好む場合(特に長いクエリに役立ちます):
$ results = db :: select( 'select * from users where id =:id'、['id' => 5]);
- 使用
?
ポジションプレースホルダー向け - または使用
:name
- 2番目の引数として配列内の値を渡す
これにより、クエリが安全で読みやすくなります。
Eloquentモデルで生のクエリを実行します
Eloquentを使用しているが、それでもRAW SQLを書きたい場合は、クエリ内でDB::raw()
メソッドを使用できます。
例えば:
$ users = user :: select(['id'、 'name'、db :: raw( 'count(order.id)as order_count')))) - > leftjoin( 'orders'、 'orders.user_id'、 '='、 'users.id')) - > groupby( 'users.id') - > get();
-
DB::raw()
その部分を生のsqlとして扱うようにlaravelに伝えます - 集約またはカスタムロジックを使用して複雑なクエリを構築するときに役立ちます
- また、声明で条項や注文する場所でそれを使用することもできます
ただし、注意してください: DB::raw
使いすぎると、クエリが維持またはテストが難しくなる可能性があります。
生のクエリを使用するタイミング
すべての状況に生のSQLは必要ありませんが、それが理にかなっている場合があります:
- クエリビルダーの方法で表現するのが難しい複雑な結合またはサブ征服を扱うとき
- SQLを完全に制御したいアプリのパフォーマンスクリティカルな部分について
- Laravelの命名または構造規則に従わないレガシーデータベースを操作するとき
覚えておいてください:RAW SQLは特定のデータベースエンジンにより密接に結びついているため、後でデータベースを切り替える予定がある場合は、複雑になる可能性があります。
基本的に、それがLaravelでRAW SQLクエリを安全かつ効果的に実行する方法です。複雑ではありませんが、セキュリティと構造に注意を払う必要があります。
以上がLaravelで生のSQLクエリを実行する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undress AI Tool
脱衣画像を無料で

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

Laravelの構成キャッシュは、すべての構成ファイルを単一のキャッシュファイルにマージすることにより、パフォーマンスを向上させます。生産環境で構成キャッシュを有効にすると、各リクエストでI/O操作を削減し、ファイルの解析を行うと、構成の読み込みが高速化されます。 1.アプリケーションが展開され、構成が安定しており、頻繁な変更は必要ありません。 2。構成を有効にして変更した後、phpartisanconfigを再実行する必要があります:キャッシュを有効にします。 3.構成ファイルのランタイム条件に依存する動的ロジックまたはクロージャーを使用しないでください。 4.トラブルシューティングの問題の場合、まずキャッシュをクリアし、.ENV変数を確認して、再キャッシュする必要があります。

usemockeryforcustomdependenciesbysettingtintingations withshouldreceive()。2。uselaravel’sfake()methodforfacadeslikemail、queue、andhttptopreventreal interactions.3.replacecontainer-boundserviceswith

LaravelのEloquentsCopesは、ローカルスコープとグローバルスコープに分割された一般的なクエリロジックをカプセル化するツールです。 1.ローカルスコープは、範囲から始まるメソッドで定義されており、post :: published()など、明示的に呼び出される必要があります。 2.グローバルスコープは、ソフト削除またはマルチテナントシステムによく使用されるすべてのクエリに自動的に適用され、スコープインターフェイスをモデルに実装および登録する必要があります。 3.スコープには、年または月ごとに記事をフィルタリングするなどのパラメーターを装備でき、呼び出し時に対応するパラメーターが渡されます。 4.コードの明確さと再利用性を改善するために使用する場合、命名仕様、チェーンコール、一時的な無効化、および組み合わせの拡張に注意してください。

紹介テーブルを作成して、紹介、紹介、推奨コード、使用時間を含む推奨関係を記録します。 2.推奨データを管理するために、ユーザーモデルのBelongStomanyとHasmanyの関係を定義します。 3.登録時に一意の推奨コードを生成します(モデルイベントを通じて実装できます)。 4.登録中にパラメーターをクエリすることにより、推奨コードをキャプチャし、検証後に推奨関係を確立し、自己称賛を防ぎます。 5.推奨されるユーザーが指定された動作(サブスクリプション順序)を完了した場合、報酬メカニズムをトリガーします。 6.共有可能な推奨リンクを生成し、Laravel Signature URLを使用してセキュリティを強化します。 7.推奨事項の総数や変換された番号など、ダッシュボードに推奨統計を表示します。データベースの制約、セッション、またはCookieが持続することを確認する必要があります。

CheckPhp> = 8.1、Composer、およびWebserver; 2.CloneOrCreateProjectAndRunComposErinStall; 3.Copy.Env.Exampleto.ENVANDRUNPHPARTISANKEY :generate; 4.setDatabaseCredentialSin.EnvandrunphpartisanMigrate-- Seed; 5.StartServerWithPhpartisEnserve; 6.optionallyrunnpmins

createahelpers.phpfileinapp/helperswithcustomfunctionslikeformatprice、isactiveroute、andisadmin.2.addthefiletothe "files" sectionofcomposer.jsonunderautoload.3.3.runcomposerdump-autoloadtomadtomakeTomeTheEfunctionSglunctionSglovalliableableableableableableableableableableableableabuntion

chooseafeatureflagstrategysuchasconfigベース、データベース駆動型、orhird-partytoolslikeflagsmith.2.setupadatabase-drivensystemby-drivensystemmigrationforafeature_flagstablewithname、evanabled、andrulesfields、thenrunthigration.3

シーダーファイルの作成:phpartisanmake:seederuserseederを使用してシーダークラスを生成し、実行方法のモデルファクトリーまたはデータベースクエリを介してデータを挿入します。 2。Databaseseederで他のシーダーを呼び出す:sulderseeder、Postseederなどを登録$ this-> call()を介して依存関係が正しいことを確認します。 3。シーダーの実行:PHPARTISANDBを実行する:種子をすべて登録したすべてのシーダーを実行するか、PHPARTISANMIGRATE:FRESS-シードを使用してデータをリセットして補充します。 4
