ホームページ  >  記事  >  バックエンド開発  >  「PHP のコア技術と実践」 - PHP とデータベースの基礎

「PHP のコア技術と実践」 - PHP とデータベースの基礎

WBOY
WBOYオリジナル
2016-06-23 13:15:42934ブラウズ

  1. PDO (PHP DATA OBJECT)、PHP は市場のほぼすべてのデータベースをサポートしますが、抽象化レベルでは必然的に統一されたアクセス インターフェイスが不足するため、複数のデータベースにアクセスするための共通インターフェイス、つまり抽象データベースを提供する PDO が登場しました。モデル PDO 拡張機能は単なる抽象化レイヤーであり、データベースにアクセスするには特定のデータベース PDO ドライバーを使用する必要があります。前に書いたのでここにはメモを投稿しません。これまでに学んだことのないことについてだけ書いてください。
  2. PDO 効率: PDO の CRUD 効率は MYSQL 直接接続の場合よりも約 5% ~ 15% 低く、プロジェクトに運用効率に関する厳しい要件がある場合、差異は大きくなります。 MYSQL または MYSQLI。PDO の負荷に関しては、PDO が長い接続を開始した後、負荷は MYSQL よりも高く、MYSQL/ORACLE への PDO 接続の速度は直接接続よりも優れています。
  3. データベース アプリケーションの最適化の基本的なステートメント最適化に関する 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. 不必要な並べ替え操作を行わず、インデックス内で並べ替えを完了してください。可能な限り
  4. インデックスとパフォーマンス分析は実行効率を分析します。 set @@profiling=1; select * from tableName where 条件を表示するか、クエリ n の詳細なパフォーマンス レポートを取得します。パフォーマンスのボトルネック、同じステートメントの 2 回目 SQL キャッシュされた結果により、クエリは最初のクエリより明らかに高速です。 MYSQL インデックスを構築および使用するための基本原則: キー フィールドのインデックスを合理的に設計して使用する インデックスを構築する場合と構築しない場合のクエリ速度の差は 100 倍近くあり、インデックスを構築しない場合と同じ効果があります。インデックスの維持にはコストがかかります。各テーブルのインデックスは 5 つ未満にする必要があります。たとえば、結果セット内の 1 つの列にインデックスを作成しないでください。性別は 0 と 1 の 2 種類のみです。このフィールドにインデックスを構築するのはそれほど難しくはありません。インデックスの構築に役立つフィールド結果セットは、均等に分散するか、正規分布に準拠するのが最適です
  5. サーバーと構成 MYSQL で一般的に使用されるエンジンの比較---------------MyISAM----------メモリ ----------InnoDB の目的- --------クイック読み取り----------メモリデータ---------- -ロックの完全なトランザクションサポート-----------フルテーブル ロック -------完全なテーブル ロック -------行ロックの耐久性の複数の分離レベル -------テーブルベースのリカバリ --ディスク IO なし、耐久性なし- --ログベースのリカバリ トランザクションのサポート------サポートされません-----サポートされません---------サポートされるインデックス タイプ---B ツリー/フルテキスト/R ツリー --- ハッシュ/B ツリー ---ハッシュ/B ツリー
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。