MySQLのストレージエンジンInnoDBとMyISAMの詳細説明
1.InnoDB ストレージ エンジン
InnoDB は MySQL5.5 のデフォルトのストレージ エンジンになります。 InnoDB は、大量の短期トランザクションを処理するように設計されたトランザクション ストレージ エンジンです。そのパフォーマンスと自動クラッシュ回復機能により、非トランザクション シナリオでも人気があります。
したがって、次のように言うことができます。「 InnoDB にない機能を使用する必要があり、それを置き換える他の方法がない場合を除き、InnoDB を優先する必要があります」。
InnoDB データはテーブルスペースに保存され、各テーブルのデータとインデックスを別のファイルに保存できます。
InnoDB は MVCC を使用して高い同時実行性をサポートし、4 つの標準分離レベルを実装します。デフォルトのレベルは REPEATABLE READ (反復可能読み取り) であり、ギャップ ロック戦略によりファントム読み取りが防止されます。
InnoDB はクラスター化インデックスに基づいて構築されており、主キー クエリに対して高いパフォーマンスを発揮します。
InnoDB は、XtraBackup ツールを通じて実現できる真のホット バックアップをサポートしています。
InnoDB は、ディスクからデータを読み取る際の予測可能な先読み、メモリ内にハッシュ インデックスを自動的に作成する機能、挿入操作を高速化できる挿入バッファーなど、多くの内部最適化を行いました。
アプリケーションシナリオ : オンラインホットバックアップが必要です
データ量が多く、システム崩壊後にシステムを迅速に回復する必要があります。注文処理など。
2.MyISAM ストレージ エンジンMySQL5.1 より前は、MyISAM がデフォルトのストレージ エンジンでした。 MyISAM はトランザクションと行レベルのロックをサポートしておらず、その最大の欠点はクラッシュ後に安全に回復できないことです。
.MyISAM は、テーブルをデータ ファイルとインデックス ファイルの 2 つのファイルに保存します。
MyISAM はテーブル全体をロックし、読み取り時に必要なすべてのテーブルに共有ロックを追加し、書き込み時に排他ロックを追加します。ただし、テーブルに読み取りクエリがある場合は、テーブルに新しいレコードを挿入することもできます (同時挿入)
MyISAM はチェックと修復操作を手動または自動で実行できますが、データ損失が発生する可能性があり、修復操作は非常に遅くなります。
MyISAM テーブル内の BLOB や TEXT などの長いフィールドでも、最初の 500 文字に基づいてインデックスを作成できます。 MyISAM は、単語の分割に基づいて作成されたインデックスである全文インデックス作成もサポートしており、複雑なクエリをサポートできます。
テーブルの作成時に MyISAM が DELAY_KEY_WRITE (インデックス キーの遅延更新) を指定した場合、インデックスは各変更が完了したときにメモリ内のキー バッファに書き込まれます。キー バッファがクリアされるか、またはクリアされるまで、対応するキー バッファは書き込まれません。テーブルが閉じられると、インデックス ブロックがディスクに書き込まれ、書き込みパフォーマンスが大幅に向上します。ただし、データベースまたはホストがクラッシュすると、インデックスが破損する可能性があります。
アプリケーション シナリオ
: は、一般的なログ タイプのアプリケーションなど、主に SELECT および Insert 操作です。
以上がMySQLのストレージエンジンInnoDBとMyISAMの詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

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

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

ホットトピック









MySQLデータベースでは、ユーザーとデータベースの関係は、アクセス許可と表によって定義されます。ユーザーには、データベースにアクセスするためのユーザー名とパスワードがあります。許可は助成金コマンドを通じて付与され、テーブルはCreate Tableコマンドによって作成されます。ユーザーとデータベースの関係を確立するには、データベースを作成し、ユーザーを作成してから許可を付与する必要があります。

MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。

NAVICAT自体はデータベースパスワードを保存せず、暗号化されたパスワードのみを取得できます。解決策:1。パスワードマネージャーを確認します。 2。NAVICATの「パスワードを記憶する」機能を確認します。 3.データベースパスワードをリセットします。 4.データベース管理者に連絡してください。

1.正しいインデックスを使用して、データの量を削減してデータ検索をスピードアップしました。テーブルの列を複数回検索する場合は、その列のインデックスを作成します。あなたまたはあなたのアプリが基準に従って複数の列からのデータが必要な場合、複合インデックス2を作成します2。選択した列のみを避けます。必要な列のすべてを選択すると、より多くのサーバーメモリを使用する場合にのみサーバーが遅くなり、たとえばテーブルにはcreated_atやupdated_atやupdated_atなどの列が含まれます。

NAVICATプレミアムを使用してデータベースを作成します。データベースサーバーに接続し、接続パラメーターを入力します。サーバーを右クリックして、[データベースの作成]を選択します。新しいデータベースの名前と指定された文字セットと照合を入力します。新しいデータベースに接続し、オブジェクトブラウザにテーブルを作成します。テーブルを右クリックして、データを挿入してデータを挿入します。

MySQLでテーブルをコピーするには、新しいテーブルの作成、データの挿入、外部キーの設定、インデックスのコピー、トリガー、ストアドプロシージャ、および機能が必要です。特定の手順には、同じ構造を持つ新しいテーブルの作成が含まれます。元のテーブルからデータを新しいテーブルに挿入します。同じ外部キーの制約を設定します(元のテーブルに1つがある場合)。同じインデックスを作成します。同じトリガーを作成します(元のテーブルに1つがある場合)。同じストアドプロシージャまたは関数を作成します(元のテーブルが使用されている場合)。

次のコマンドでmysqlデータベースを表示します。サーバーに接続します:mysql -u username -pパスワードrun showデータベース。すべての既存のデータベースを取得するコマンド[データベース]を選択します。データベース名を使用します。テーブルを表示:表を表示します。テーブル構造を表示:テーブル名を説明してください。データを表示:[テーブル名]から[ *]を選択します。

Passwordが暗号化された形式で保存されているため、MariadbのNavicatはデータベースパスワードを直接表示できません。データベースのセキュリティを確保するには、パスワードをリセットするには3つの方法があります。NAVICATを介してパスワードをリセットし、複雑なパスワードを設定します。構成ファイルを表示します(推奨されていない、高リスク)。システムコマンドラインツールを使用します(推奨されません。コマンドラインツールに習熟する必要があります)。
