MySQLデータベースエンジンをInnoDBに変更する

MySQLデータベースエンジンをInnoDBに変更する

PS: ここではPHPStudy2016を使用しています

1. 変更中にMySQLを停止する

2. my.iniを変更する

デフォルトのストレージエンジン=INNODB

3. 変更後、D:\phpStudy\MySQL\data の下にある ib で始まるログファイルを削除します。

4. MySQLを起動する

セットアップ後、Navicat を使用して、ターゲット データベースと同じエンコーディングで新しいデータベースを作成し、それをコピーします。コピーされたデータ テーブルのデータ エンジンは、ソース データ テーブルのデータ エンジンと一致します。

注: データテーブルエンジンを変更する

テーブル名 type=InnoDB を変更します

補足: InnoDB および MyISAM エンジンの選択とデフォルト エンジンの変更

MySQL データベースのデフォルト エンジンが Innodb に変更される [構成]

InnoDB と MyISAM は、MySQL を使用する際に多くの人が最もよく使用する 2 つのテーブル タイプです。これらの 2 つのテーブル タイプには、特定のアプリケーションに応じて、それぞれ長所と短所があります。

基本的な違いは、MyISAM タイプはトランザクション処理などの高度な処理をサポートしていないのに対し、InnoDB タイプはサポートしていることです。 MyISAM タイプのテーブルはパフォーマンスを重視し、InnoDB タイプよりも高速に実行されますが、トランザクション サポートは提供されません。InnoDB は、トランザクション サポートと、外部キーなどの高度なデータベース機能を提供します。

なぜデフォルトのエンジンを変更する必要があるのでしょうか? 理由は実はとても簡単です。私が使用しているデフォルトの MySQL エンジンは MyISAM ですが、MyISAM はトランザクション処理をサポートしていないため、エンジンを変更する必要があります。

デフォルトの MySQL エンジンを InnoDB に変更するには、次の手順に従います。

デフォルトでは、Mysql は InnoDB ストレージ エンジンの使用をオフにします。次のようにして、InnoDB をデフォルトのエンジンとして設定します。

1. MySQL ストレージ エンジンのステータスを確認します。mysql>show engines の結果は InnoDB | YES となり、この MySQL データベース サーバーが InnoDB エンジンをサポートしていることを示します。

2. InnoDBをデフォルトのエンジンとして設定します。my.ini設定ファイルの[mysqld]の下にdefault-storage-engine=INNODBを追加します。

3. MySQLサーバーを再起動する

4. MySQL データベースにログインし、mysql>show engines を実行します。InnoDB | DEFAULT が表示された場合、InnoDB がデフォルトのエンジンとして正常に設定されたことを意味します。

上記は私の個人的な経験です。参考になれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。間違いや不備な点がありましたら、遠慮なくご指摘ください。

以下もご興味があるかもしれません:
  • MySQL InnoDB アーキテクチャの概要
  • MySQL InnoDB ReplicaSet の簡単な紹介
  • MySQL InnoDB ストレージエンジンのメモリ管理の詳細な説明
  • MySQL Innodbの主な機能挿入バッファ
  • MySQL InnoDB ロックの概要
  • MySQL の innodb_flush_log_at_trx_commit と sync_binlog を区別する方法
  • MySQL InnoDB ロック メカニズムの詳細な例
  • MySQLテクノロジーにおけるInnoDBロックの詳細な説明
  • MySQL InnoDBストレージエンジンについて簡単に説明します
  • MySQL InnoDB テーブルスペース暗号化の例の詳細な説明
  • MySQL InnoDB トランザクション ロック ソースコード分析

<<:  Dockerはコンテナにポートを動的に公開します

>>:  マークアップ言語 - HTML を学んだ後に何を学ぶべきか?

推薦する

MySQL データ型 DECIMAL の詳細な分析

序文:金額の保存など、小数点数を保存し、精度要件がある場合、通常は DECIMAL フィールド タイ...

Vue プロジェクトで axios をカプセル化する方法 (http リクエストの統合管理)

1. 要件Vue.js フレームワークを使用してフロントエンド プロジェクトを開発する場合、サーバ...

Linux で SpringBoot jar プログラム デプロイメント シェル スクリプトを起動および停止する方法

では早速、コードをお見せしましょう。具体的なコードは次のとおりです。 #!/bin/bash cd ...

Dockerのセキュリティについて Docker-TLS暗号化通信の問題

目次1. Dockerのセキュリティ問題2. Dockerアーキテクチャの欠陥とセキュリティメカニズ...

フィールドの文字セットの違いによる MySQL のインデックス失敗の解決策

インデックスとは何ですか?なぜインデックスを作成するのですか?インデックスは、列に特定の値を持つ行を...

js キャンバスは角丸画像を実現します

この記事では、角を丸くするためのjsキャンバスの具体的なコードを参考までに紹介します。具体的な内容は...

JavaScriptのループの違いについての詳細な説明

目次序文列挙可能なプロパティ反復可能なオブジェクトforEachメソッドとmapメソッドチェーン呼び...

MySQL タイムブラインドインジェクションの 5 つの遅延方法

MySQL タイム ブラインド インジェクションの 5 つの遅延方法 (PWNHUB の予期しない解...

Vue でインデックスをキー属性値として使用することが推奨されないのはなぜですか?

目次序文キーの役割差分アルゴリズムにおけるキーの役割ヘッドノードを同期するテールノードを同期する新し...

JSは画像の滝の流れの効果を実現します

この記事では、画像ウォーターフォールフローを実現するためのJSの具体的なコードを参考までに共有します...

一般的な Dockerfile コマンドの使用方法の紹介

目次01 CM 02 エントリーポイント03 ワークディレクトリ04 環境05 ユーザー06巻07 ...

Nginx の場所と proxy_pass パスの設定の問題の概要

目次1. Nginxロケーションの基本設定1.1 Nginx 設定ファイル1.2 Pythonスクリ...

JavaScript 以外の静的リソースのバンドルの詳細

目次1. パッケージングツールでのカスタムインポート2. ブラウザとバンドラの共通インポート構文3....

オンラインMySQL自動増分IDが使い果たされた場合の対処方法

目次テーブル定義の自動増分 ID InnoDBシステムはrow_idを自動的に増加させるシドInno...

GZIP 圧縮 Tomcat と Web パフォーマンスの改善プロセス図

1. はじめに最近、あるプロジェクトに取り組んでいたのですが、サーバーからクライアントに返される J...