MySQL の機能
開発中のアプリケーションは以下の機能に基づいています:
(1) 理解: PHP を使用してデータベースに接続する方法を知っている、簡単なインデックスを作成する方法を知っている。ツールを使用してデータベースの簡単な操作 (データベース テーブル構造データの追加、削除、変更など) を実行します。
(2) 知識: 開発アプリケーション用のデータベースを設計する方法、効果的なインデックスを作成する方法、SQL パフォーマンスを分析するために Explain を使用する方法、ストレス テストなどを理解する。
(3) 非常に精通している: データベース インデックス、ストレージ エンジンの原理、操作メカニズムを深く理解しており、高性能でスケーラブルなデータベース構造/アーキテクチャを効果的に構築し、データベース パフォーマンス構成を効果的に最適化およびデバッグできる。データベースの稼働状況を分析します。
(4) 熟練: 簡単に言えば、上記の能力をすべて備えていると同時に、高負荷の分散環境での管理の最適化に長年の経験を持っています。
観察と対話の経験によると、PHPer の 70% が理解段階にあり、25% が精通段階にあり、>4% が非常に精通しています。熟練した人は基本的に PHPer ではありません。
◆このグループの 70% は、MySQL を単なる記憶媒体であると考え、メモリと CPU を追加すれば問題が解決すると考えており、MySQL を無視している可能性が高いです。
典型的なインシデント: join、order by、group by およびその他のステートメントのパフォーマンスがめちゃくちゃで、データベースがまったく設計されておらず (1 つのメイン テーブル、N 個の付録テーブルなどに分割することに限定されている)、フィールド タイプと機能が不明瞭で、大きなテーブルで問題が発生する 複雑なクエリは役に立たない。
◆このグループの 20% の人は、MySQL の動作メカニズムを十分に理解しておらず、MySQL のパフォーマンスに影響を与える重要な要素について明確ではなく、習熟していません。
典型的なインシデント: マニュアルは理解しているが、インデックス作成の原理や、データベースにおけるバイナリ ツリーや HASH などのアルゴリズムの役割を説明できない
◆ グループの 4% は基本的に DBA の機能を実行する資格を持っています。
OOP 機能
(1) 理解する: 変数のスコープ、型、意味を理解し、継承メカニズムなどを理解し、再利用とカプセル化の概念を理解します。
(2) 知識: インターフェース、抽象化、その他のテクノロジーを使用してプログラムを開発することに熟達し、その意味を理解することが一般的です。
(3) 非常に精通している: OOP アーキテクチャ設計の経験があり、デザイン パターン、UML に精通し、PHP オブジェクト操作メカニズム、コンテンツ管理などに精通しています。
(4) 熟練: PHP に限定されず、アーキテクト レベルである必要があります。
OOP に精通していると主張しながら、パブリック、プライベート、保護、静的についてさえ説明できない人によく会います。彼らは正式な OOP プロジェクトを経験したことがないはずです。
大規模な Web サイトの経験
(1) 理解: PHP で開発されたキャッシュ アプリケーション (Memcache、APC など) に慣れており、特定のセッション処理ソリューションに慣れている。 PHP データ接続プール アプリケーションに精通している。PHP プログラミングのパフォーマンスの最適化について学習します。
(2) 知識: 分散キャッシュとキャッシュ パフォーマンスの最適化をマスターし、ストレージ システム、ファイル システム、データベースに精通し、スケーラブルなプラットフォームを開発します。負荷分散と組み合わせてトラフィックを合理的に整理し、PHP の動作パフォーマンスを監視および分析できます。
(3) 非常に精通しています: PHPer の段階を超えた、システム アナリストの能力を備えています。
(4) 熟練しています。
DOM 開発機能