検索
ホームページバックエンド開発PHPチュートリアルPHP プログラミングのヒント: 指定されたフィールドを持つ配列データをインデックスとして返す_PHP チュートリアル

PHP プログラミングのヒント: 指定されたフィールドを持つ配列データをインデックスとして返す_PHP チュートリアル

Jul 20, 2016 am 11:13 AM
phpのためにによる分野開発する場合私たち指定データ配列索引プログラミングスキル戻るプロジェクト

新しいプロジェクトに出会ってから開発が完了するまで、私たちは自分が書いたコードをじっくりと読み返すことが多く、その多くは以前に使いこなしたコードです。したがって、新しいプロジェクトを完了するたびに、プロジェクトの概要とコードの概要を適切に実行すると、将来のプロジェクトでそれを使用できるようになり、コードの最適化やより良いアイデア、より迅速な実装方法など、予期せぬ利益が得られる可能性が非常に高くなります。 。

優れたプログラム開発者を決定するのは、コードの量ではなく、コードの単純さと、複雑なロジックにもかかわらず実装の容易さである場合があります。これらは、プログラマーが優れたプログラマーであるかどうかを示す要素です。私たちは、昼も夜も夜遅くまで残業して、大量のコードを急いで書くプログラマーにはなりたくないのです。

このブログでは、いくつかの PHP プログラミング スキルを共有します。スキルの中には、他の人のコードを見て学んだものと、私自身が要約したものがあります。

特定のフィールドをインデックスとして使用して、データベースから取得したデータ配列を返します

例を挙げると簡単です:

他の Web サイトからの指定したサイトのトラフィックをカウントし、各 Web サイトのトラフィックを毎日チェックするための小さなバックエンドを作成するとします。まず 2 つのデータテーブルを作成しましょう:

表 1. サイト構成表 (これらの Web サイトのトラフィックのみがカウントされます)

リーリー

表 2. サイトのトラフィック統計テーブル (ユーザーごとに 1 つのレコード)

リーリー

site_config テーブルの読み取り操作は書き込み操作よりも大きいため、タイプは MyISAM に設定され、site_stat テーブルの書き込み操作は読み取り操作よりも大きいため、テーブル タイプを InnoDB に設定します。 (これらはデータ設計時に考慮する必要があることであり、速度が大幅に向上します)。

トピックに戻り、テーブル site_config に複数のデータがある場合:

データ形式は次のとおりです: id、sid、site_url、add_time

1,200,baidu.com,2013-06-30 14:20:00

2,201,google.com,2013-06-30 14:20:00

3,202,cnblogs.com,2013-06-30 14:20:00

4,203、codejia.net、2013-06-30 14:20:00

次のように、サイト トラフィック統計テーブル site_stat に一部のデータが生成されています。

データ形式は次のとおりです: id、sid、ip_address、add_time

1,200,167.87.32.4,2013-06-30 14:40:00

2,200,192.168.11.56、2013-06-30 14:40:10

3,202,167.87.32.4,2013-06-30 14:40:10

4,202,192.168.11.56、2013-06-30 14:40:20

5,203,167.87.32.4,2013-06-30 14:40:20

6,202,10.10.10.10,2013-06-30 14:40:30

7,200,167.87.32.4,2013-06-30 14:40:31

バックグラウンドで作成する必要があるレポート形式は、日付、WebサイトID、WebサイトURL、トラフィック数(トラフィックのないサイトも表示する必要があり、トラフィックは0と表示されます)

日付に基づいてテーブル site_config を左結合し、テーブル site_stat でグループ化してから左結合することを考えるかもしれませんが、これは明らかに私が共有する方法ではありません。

これを行うには 2 つの SQL を使用します。1 つはすべてのサイトを取得することで、もう 1 つは指定された日付のサイトのトラフィック統計を取得することです。

SQL1 はすべてのサイトを取得します:

リーリー

SQL2 はサイト統計を取得します (今日の場合):

リーリー

先ほど述べたことの多くは、渡されたフィールドをインデックスとして使用して 2 次元配列を返す PHP メソッドを共有しましょう。 リーリー

SQL とインデックスを作成する必要があるフィールドを渡します。前提として、渡されるフィールドは select によって返されるフィールドの中にある必要があります。

すべてのサイトを取得する場合は、過去フィールドを渡す必要はありませんが、サイトのトラフィック統計を取得する場合は、次のようなサイト sid を渡します。 リーリー

最後に、レポートを表示するときに、foreach を使用して $sites をループし、トラフィックを取得するときに、配列 $data に移動して、インデックス sid を持つデータを取得します。

とても便利でマスターしやすいので、よく使っています。

最後に、上の表の統計結果レポートを見てください:

形式は次のとおりです: 日付、ウェブサイトID、ウェブサイトURL、トラフィック数

2013-06-30,200,baidu.com,3

2013-06-30,201,google.com,0

2013-06-30,202,cnblogs.com,3

2013-06-30,203,codejia.net,1

要約: これだけ書くと、ほんの小さなスキルを示しているように見えますが、このスキルを過小評価しないでください。かなりの時間を節約できます。そのため、皆さんもコードを書くときにもっとまとめて、ブログパークに来てみんなとコミュニケーションを取りながら学んでいけば、あなたのプログラミングレベルは確実に早く上がります!

http://www.bkjia.com/PHPjc/440351.html

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/440351.html技術記事多くの場合、新しいプロジェクトに出会ってから開発が完了するまで、自分が書いたコードをじっくりと読み返しますが、その多くは以前に使いこなしたコードです。それでは最後に…
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHP対Python:違いを理解しますPHP対Python:違いを理解しますApr 11, 2025 am 12:15 AM

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

PHP:それは死にかけていますか、それとも単に適応していますか?PHP:それは死にかけていますか、それとも単に適応していますか?Apr 11, 2025 am 12:13 AM

PHPは死にかけていませんが、常に適応して進化しています。 1)PHPは、1994年以来、新しいテクノロジーの傾向に適応するために複数のバージョンの反復を受けています。 2)現在、電子商取引、コンテンツ管理システム、その他の分野で広く使用されています。 3)PHP8は、パフォーマンスと近代化を改善するために、JITコンパイラおよびその他の機能を導入します。 4)Opcacheを使用してPSR-12標準に従って、パフォーマンスとコードの品質を最適化します。

PHPの未来:適応と革新PHPの未来:適応と革新Apr 11, 2025 am 12:01 AM

PHPの将来は、新しいテクノロジーの傾向に適応し、革新的な機能を導入することで達成されます。1)クラウドコンピューティング、コンテナ化、マイクロサービスアーキテクチャに適応し、DockerとKubernetesをサポートします。 2)パフォーマンスとデータ処理の効率を改善するために、JITコンパイラと列挙タイプを導入します。 3)パフォーマンスを継続的に最適化し、ベストプラクティスを促進します。

PHPの抽象クラスまたはインターフェイスに対して、いつ特性を使用しますか?PHPの抽象クラスまたはインターフェイスに対して、いつ特性を使用しますか?Apr 10, 2025 am 09:39 AM

PHPでは、特性は方法が必要な状況に適していますが、継承には適していません。 1)特性により、クラスの多重化方法が複数の継承の複雑さを回避できます。 2)特性を使用する場合、メソッドの競合に注意を払う必要があります。メソッドの競合は、代替およびキーワードとして解決できます。 3)パフォーマンスを最適化し、コードメンテナビリティを改善するために、特性の過剰使用を避け、その単一の責任を維持する必要があります。

依存関係噴射コンテナ(DIC)とは何ですか?また、なぜPHPで使用するのですか?依存関係噴射コンテナ(DIC)とは何ですか?また、なぜPHPで使用するのですか?Apr 10, 2025 am 09:38 AM

依存関係噴射コンテナ(DIC)は、PHPプロジェクトで使用するオブジェクト依存関係を管理および提供するツールです。 DICの主な利点には、次のものが含まれます。1。デカップリング、コンポーネントの独立したもの、およびコードの保守とテストが簡単です。 2。柔軟性、依存関係を交換または変更しやすい。 3.テスト可能性、単体テストのために模擬オブジェクトを注入するのに便利です。

通常のPHPアレイと比較して、SPL SPLFIXEDARRAYとそのパフォーマンス特性を説明してください。通常のPHPアレイと比較して、SPL SPLFIXEDARRAYとそのパフォーマンス特性を説明してください。Apr 10, 2025 am 09:37 AM

SplfixedArrayは、PHPの固定サイズの配列であり、高性能と低いメモリの使用が必要なシナリオに適しています。 1)動的調整によって引き起こされるオーバーヘッドを回避するために、作成時にサイズを指定する必要があります。 2)C言語アレイに基づいて、メモリと高速アクセス速度を直接動作させます。 3)大規模なデータ処理とメモリに敏感な環境に適していますが、サイズが固定されているため、注意して使用する必要があります。

PHPは、ファイルを安全に処理する方法をどのように処理しますか?PHPは、ファイルを安全に処理する方法をどのように処理しますか?Apr 10, 2025 am 09:37 AM

PHPは、$ \ _ファイル変数を介してファイルのアップロードを処理します。セキュリティを確保するための方法には次のものが含まれます。1。アップロードエラー、2。ファイルの種類とサイズを確認する、3。ファイル上書きを防ぐ、4。ファイルを永続的なストレージの場所に移動します。

Null Coulescingオペレーター(??)およびNull Coulescing Assignment Operator(?? =)とは何ですか?Null Coulescingオペレーター(??)およびNull Coulescing Assignment Operator(?? =)とは何ですか?Apr 10, 2025 am 09:33 AM

JavaScriptでは、nullcoalescingoperator(??)およびnullcoalescingsignmentoperator(?? =)を使用できます。 1.??最初の非潜水金または非未定されたオペランドを返します。 2.??これらの演算子は、コードロジックを簡素化し、読みやすさとパフォーマンスを向上させます。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

SublimeText3 中国語版

SublimeText3 中国語版

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

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター