Mysql には 4 つの分離レベルがあります: 1. コミットされていないコンテンツを読み取ります。この分離レベルでは、すべてのトランザクションが他のコミットされていないトランザクションの実行結果を確認できます。 2. 送信コンテンツを読み取ります。トランザクションが送信された後でのみ、トランザクションによって変更されたデータが他のものによって参照されるようになります。 3. 反復可能な読み取り。トランザクションの実行中に表示されるデータは、トランザクションの開始時に表示されるデータと常に一致します。 4. 直列化可能; トランザクションを強制的にソートし、トランザクションが互いに競合することを不可能にし、それによってファントム読み取りの問題を解決します。
このチュートリアルの動作環境: Windows7 システム、mysql8 バージョン、Dell G3 コンピューター。
トランザクションには、ACID 特性 (原子性、一貫性、分離性、耐久性、つまり原子性、一貫性、分離性、耐久性) があります。
Mysql の 4 つの分離レベル
SQL 標準では、内部および外部トランザクションを制限するいくつかの特定のルールを含む 4 種類の分離レベルが定義されています。見えるものと見えないもの。一般に、分離レベルが低いほど高い同時実行性がサポートされ、システムのオーバーヘッドが低くなります。 [ビデオ チュートリアルの推奨事項: Mysql チュートリアル ]
1. コミットされていないコンテンツの読み取り (読み取り-非コミット)
この分離レベルでは、すべてのトランザクションが他のコミットされていないトランザクションの実行結果を確認します。この分離レベルは他のレベルと比べてパフォーマンスがそれほど優れていないため、実際のアプリケーションではほとんど使用されません。
この分離レベルで発生する問題は、ダーティ リード、つまりコミットされていないデータが読み取られることです。
2. 読み取りコミットされたコンテンツ (読み取りコミット)
これは、ほとんどのデータベース システムのデフォルトの分離レベルです (ただし、MySQL のデフォルトではありません)。これは分離の単純な定義を満たしています。つまり、トランザクションはコミットされたトランザクションによって行われた変更のみを確認できます。
この分離レベルの問題は次のとおりです。Nonrepeatable Read、つまり、Nonrepeatable Read は、同じトランザクション内でまったく同じ select ステートメントを実行すると、異なる結果が表示される可能性があることを意味します。
この状況の理由は次のとおりです:
1) クロス トランザクションに新しいコミットがあり、その結果データが変更されます;
2)。データベースが変更されると、複数のインスタンスによって操作される場合、同じトランザクションの他のインスタンスは、インスタンスの処理中に新しいコミットを持つ可能性があります
3.Repeatable-read
これは MySQL のデフォルトのトランザクションです分離レベル。データを同時に読み取るときに、同じトランザクションの複数のインスタンスが同じデータ行を参照できるようにします。
しかし理論的には、これはファントムリードという別のやっかいな問題を引き起こすことになります。
簡単に言えば、ファントム読み取りとは、ユーザーが特定の範囲のデータ行を読み取るときに、別のトランザクションがその範囲に新しい行を挿入することを意味します。ユーザーが範囲内のデータ行を読み取ると、は新しい「ファントム」行です。
InnoDB および Falcon ストレージ エンジンは、マルチバージョン同時実行制御 (MVCC、Multiversion Concurrency Control) メカニズムを通じてこの問題を解決します。
4. シリアル化可能
これは最高の分離レベルであり、トランザクションが互いに競合しないように強制的に順序付けすることで錯覚を解決します。 。つまり、読み取られた各データ行に共有ロックが追加されます。このレベルでは、多数のタイムアウトやロック競合が発生する可能性があります。
このレベルでは、大量のタイムアウトやロック競合が発生する可能性があります。
推奨学習: mysql ビデオ チュートリアル
以上がMySQL にはいくつかの分離レベルがありますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

mysqloffersvariousstorageEngines、それぞれのfordifferentusecases:1)Innodbisidealforapplicationsingingidcomplianceanceandhighconcurrency、support transactions andforeignkeys.2)myisamisbestforread-havyworkloads、transactionsupptort.3)

MySQLの一般的なセキュリティの脆弱性には、SQLインジェクション、弱いパスワード、不適切な許可構成、および非合事ソフトウェアが含まれます。 1。SQL注射は、前処理ステートメントを使用することで防ぐことができます。 2。強力なパスワード戦略を強制的に使用することにより、弱いパスワードを回避できます。 3.不適切な許可構成は、ユーザー許可の定期的なレビューと調整を通じて解決できます。 4.未使用のソフトウェアは、MySQLバージョンを定期的にチェックして更新することでパッチを適用できます。

MySQLの遅いクエリを識別することは、遅いクエリログを有効にし、しきい値を設定することで実現できます。 1.スロークエリログを有効にし、しきい値を設定します。 2.スロークエリログファイルを表示および分析し、詳細な分析のためにMySQLDumpSlowやPT-Query-Digestなどのツールを使用します。 3.インデックスの最適化、クエリの書き換え、およびselect*の使用を回避することで、遅いクエリの最適化を実現できます。

MySQLサーバーの健康とパフォーマンスを監視するには、システムの健康、パフォーマンスメトリック、クエリの実行に注意する必要があります。 1)システムの健康を監視する:Top、HTOP、またはShowGlobalStatusコマンドを使用して、CPU、メモリ、ディスクI/O、ネットワークアクティビティを表示します。 2)パフォーマンスインジケーターの追跡:クエリ番号あたりのクエリ番号、平均クエリ時間、キャッシュヒット率などのキーインジケーターを監視します。 3)クエリ実行の最適化を確保します:スロークエリログを有効にし、実行時間が設定されたしきい値を超えるクエリを記録し、最適化します。

MySQLとMariaDBの主な違いは、パフォーマンス、機能、ライセンスです。1。MySQLはOracleによって開発され、Mariadbはフォークです。 2. Mariadbは、高負荷環境でパフォーマンスを向上させる可能性があります。 3.MariaDBは、より多くのストレージエンジンと機能を提供します。 4.MySQLは二重ライセンスを採用し、MariaDBは完全にオープンソースです。既存のインフラストラクチャ、パフォーマンス要件、機能要件、およびライセンスコストを選択する際に考慮する必要があります。

MySQLはGPLライセンスを使用します。 1)GPLライセンスにより、MySQLの無料使用、変更、分布が可能になりますが、変更された分布はGPLに準拠する必要があります。 2)商業ライセンスは、公的な変更を回避でき、機密性を必要とする商用アプリケーションに適しています。

Myisamの代わりにInnoDBを選択する場合の状況には、次のものが含まれます。1)トランザクションサポート、2)高い並行性環境、3)高いデータの一貫性。逆に、Myisamを選択する際の状況には、1)主に操作を読む、2)トランザクションサポートは必要ありません。 INNODBは、eコマースプラットフォームなどの高いデータの一貫性とトランザクション処理を必要とするアプリケーションに適していますが、Myisamはブログシステムなどの読み取り集約型およびトランザクションのないアプリケーションに適しています。

MySQLでは、外部キーの機能は、テーブル間の関係を確立し、データの一貫性と整合性を確保することです。外部キーは、参照整合性チェックとカスケード操作を通じてデータの有効性を維持します。パフォーマンスの最適化に注意し、それらを使用するときに一般的なエラーを避けてください。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

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

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

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

ホットトピック









