「PHP のコア技術と実践」 - PHP とデータベースの基礎
- PDO (PHP DATA OBJECT)、PHP は市場のほぼすべてのデータベースをサポートしますが、抽象化レベルでは必然的に統一されたアクセス インターフェイスが不足するため、複数のデータベースにアクセスするための共通インターフェイス、つまり抽象データベースを提供する PDO が登場しました。モデル PDO 拡張機能は単なる抽象化レイヤーであり、データベースにアクセスするには特定のデータベース PDO ドライバーを使用する必要があります。前に書いたのでここにはメモを投稿しません。これまでに学んだことのないことについてだけ書いてください。
- PDO 効率: PDO の CRUD 効率は MYSQL 直接接続の場合よりも約 5% ~ 15% 低く、プロジェクトに運用効率に関する厳しい要件がある場合、差異は大きくなります。 MYSQL または MYSQLI。PDO の負荷に関しては、PDO が長い接続を開始した後、負荷は MYSQL よりも高く、MYSQL/ORACLE への PDO 接続の速度は直接接続よりも優れています。
- データベース アプリケーションの最適化の基本的なステートメント最適化に関する 10 の原則: 1. インデックス エラーの原因となる列に対する操作の実行を避けるようにしてください。select * from t where YEAR(d) >= 2011 は select * from t where に最適化されます。 d > ;= '2011-01-01'2. JOIN を使用する場合、アプリケーションは小さな結果セットを使用して大きな結果セットを駆動します。同時に、複数のテーブルを JOIN するとロックや輻輳が増加する可能性があるため、複雑な JOIN クエリを複数のクエリに分割します。 3. LIKE ファジー クエリの使用に注意し、%% を避けてください。 4. クエリが必要なフィールドのみをリストします。これは、速度に大きな影響を与えません。 5. インタラクションを保存するには、insert ステートメントを使用します。 6. 制限のベースが比較的大きい場合は、 between 制限を使用します。そのため、大量のデータにアクセスする場合は、制限を between または where に置き換えることをお勧めします。ただし、between の欠点は、途中で改行があったり、一部が読まれなかったりすると、合計の読み取り数が予想よりも少なくなってしまうことです。後続のデータを取得して比較する場合は、 desc メソッドを使用してデータを反映および検索し、前のデータのスキャンを減らし、制限のベースをできるだけ小さくします。 7. 複数のランダムなレコードを取得するために rand 関数を使用しないでください。 8. NULL の使用を避けてください。 9. count(id) ではなく count(*) を使用してください。 10. 不必要な並べ替え操作を行わず、インデックス内で並べ替えを完了してください。可能な限り インデックスとパフォーマンス分析は実行効率を分析します。 set @@profiling=1; select * from tableName where 条件を表示するか、クエリ n の詳細なパフォーマンス レポートを取得します。パフォーマンスのボトルネック、同じステートメントの 2 回目 SQL キャッシュされた結果により、クエリは最初のクエリより明らかに高速です。 MYSQL インデックスを構築および使用するための基本原則: キー フィールドのインデックスを合理的に設計して使用する インデックスを構築する場合と構築しない場合のクエリ速度の差は 100 倍近くあり、インデックスを構築しない場合と同じ効果があります。インデックスの維持にはコストがかかります。各テーブルのインデックスは 5 つ未満にする必要があります。たとえば、結果セット内の 1 つの列にインデックスを作成しないでください。性別は 0 と 1 の 2 種類のみです。このフィールドにインデックスを構築するのはそれほど難しくはありません。インデックスの構築に役立つフィールド結果セットは、均等に分散するか、正規分布に準拠するのが最適です
- サーバーと構成 MYSQL で一般的に使用されるエンジンの比較---------------MyISAM----------メモリ ----------InnoDB の目的- --------クイック読み取り----------メモリデータ---------- -ロックの完全なトランザクションサポート-----------フルテーブル ロック -------完全なテーブル ロック -------行ロックの耐久性の複数の分離レベル -------テーブルベースのリカバリ --ディスク IO なし、耐久性なし- --ログベースのリカバリ トランザクションのサポート------サポートされません-----サポートされません---------サポートされるインデックス タイプ---B ツリー/フルテキスト/R ツリー --- ハッシュ/B ツリー ---ハッシュ/B ツリー

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











PHPには4つの主要なエラータイプがあります。1。notice:わずかなものは、未定義の変数へのアクセスなど、プログラムを中断しません。 2。警告:通知よりも深刻で、ファイルを含むなど、プログラムを終了しません。 3。ファタラー:最も深刻なのは、機能を呼び出すなど、プログラムを終了します。 4。ParseError:構文エラーは、エンドタグの追加を忘れるなど、プログラムの実行を防ぎます。

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PHPでは、Password_hashとpassword_verify関数を使用して安全なパスワードハッシュを実装する必要があり、MD5またはSHA1を使用しないでください。 1)password_hashセキュリティを強化するために、塩値を含むハッシュを生成します。 2)password_verifyハッシュ値を比較して、パスワードを確認し、セキュリティを確保します。 3)MD5とSHA1は脆弱であり、塩の値が不足しており、最新のパスワードセキュリティには適していません。

PHPは、電子商取引、コンテンツ管理システム、API開発で広く使用されています。 1)eコマース:ショッピングカート機能と支払い処理に使用。 2)コンテンツ管理システム:動的コンテンツの生成とユーザー管理に使用されます。 3)API開発:RESTFUL API開発とAPIセキュリティに使用されます。パフォーマンスの最適化とベストプラクティスを通じて、PHPアプリケーションの効率と保守性が向上します。

HTTPリクエストメソッドには、それぞれリソースを取得、送信、更新、削除するために使用されるGET、POST、PUT、および削除が含まれます。 1. GETメソッドは、リソースを取得するために使用され、読み取り操作に適しています。 2. POSTメソッドはデータの送信に使用され、新しいリソースを作成するためによく使用されます。 3. PUTメソッドは、リソースの更新に使用され、完全な更新に適しています。 4.削除メソッドは、リソースの削除に使用され、削除操作に適しています。

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

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

Phpoopでは、self ::は現在のクラスを指し、親::は親クラスを指し、静的::は後期静的結合に使用されます。 1.Self ::静的方法と一定の呼び出しに使用されますが、後期静的結合をサポートしていません。 2.Parent ::サブクラスには、親クラスのメソッドを呼び出すために使用され、プライベートメソッドにアクセスできません。 3.Static ::継承と多型に適した後期静的結合をサポートしますが、コードの読みやすさに影響を与える可能性があります。
