Yii2でindexBy()を使用する方法
プロジェクト開発では、いくつかの特別な値が配列のインデックスとしてよく使用されます。通常、最初にデータをクエリしてから、配列をループ内で必要な形式。ただし、YII2 フレームワークは、より単純なメソッド IndexBy() を提供します。
all() メソッドを呼び出すと、連続する整数値でインデックス付けされた配列が返されます。
特定のフィールドまたは式の値をインデックス結果セット配列として使用したい場合があります。この目的を達成するには、all() を呼び出す前に、indexBy() メソッドを使用します。
例:
// 以uid作为key值 $query = User::find() ->select(['uid', 'name']) ->indexBy('uid') ->asArray() ->all();
クエリ結果は次のとおりです:
{ "1001": { "uid": "1001", "name": "张三" }, "1002": { "uid": "1002", "name": "李四" }, "1003": { "uid": "1003", "name": "王五" } }
式の値をインデックスとして使用する必要がある場合は、匿名関数を渡すだけで済みます。 IndexBy() メソッド:
// 以uid和name组合作为key值 $query = User::find() ->select(['uid', 'name']) ->indexBy(function ($row) { return $row['uid'] . $row['name']; // row中使用的字段名只能是查询返回的字段名 }) ->asArray() ->all();
クエリ結果は次のとおりです:
{ "1001张三": { "uid": "1001", "name": "张三" }, "1002李四": { "uid": "1002", "name": "李四" }, "1003王五": { "uid": "1003", "name": "王五" } }
注: groupBy() や orderBy() などのクエリ メソッドとは異なり、これらはSQL クエリ ステートメントから使用され、このメソッド (indexBy) はデータベースがデータを取得した後にのみ有効になります。これは、それらの列名のみを SELECT クエリで使用できることを意味します。さらに、テーブル名接続を使用して customer.id などの列名を取得する場合、結果には id 列のみが含まれるため、テーブル名のプレフィックスを付けずに ->indexBy(‘id’) を呼び出す必要があります。
推奨: 「YII チュートリアル 」
以上がYii2でindexBy()を使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック









この記事では、コンテナライゼーション、オーケストレーション、セキュリティ対策によるスケーラビリティ、信頼性、効率に焦点を当てたクラウドネイティブ環境でYIIアプリケーションを展開するためのベストプラクティスについて説明します。

この記事では、YIIをサーバーレスアーキテクチャで使用するための重要な考慮事項について説明し、ステートレス性、コールドスタート、機能サイズ、データベースの相互作用、セキュリティ、監視に焦点を当てています。また、最適化戦略と潜在的な統合をカバーしています

この記事では、組み込みモジュール、BDD、さまざまなテストタイプ、モッキング、CI統合、およびコードカバレッジを使用することに焦点を当てたCodeceptionを使用して、YIIアプリケーションをテストするための戦略について説明します。

YIIの組み込みテストフレームワークは、PHPunit統合、フィクスチャ管理、さまざまなテストタイプのサポートなどの機能を備えたアプリケーションテストを強化し、コードの品質と開発慣行を改善します。

この記事では、YIIとWebSocketsを使用したリアルタイムデータ同期の実装、パフォーマンスとセキュリティのためのセットアップ、統合、ベストプラクティスをカバーしています。

この記事では、YIIデバッグツールバー、Blackfire、New Relic、XDebug、DataDogやDynatraceなどのAPMソリューションなど、YIIアプリケーションのパフォーマンスを監視およびプロファイリングするためのツールについて説明します。

この記事では、YIIアプリケーションを生産に展開するための重要な考慮事項、環境のセットアップ、構成管理、パフォーマンスの最適化、セキュリティ、ロギング、監視、展開戦略、バックアップ/回復計画に焦点を当てています。

この記事では、SaaS開発に対するYiiの利点について説明し、パフォーマンス、セキュリティ、および迅速な開発機能に焦点を当てて、スケーラビリティを高め、市場からの時間を短縮します。
