PHP プログラミングのヒント: 指定されたフィールドを持つ配列データをインデックスとして返す_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_time1,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

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

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

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

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

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

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

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

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


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

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

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

ホットトピック



