MySQL MyISAM 庫轉換為InnoDB的方法

來源:互聯網
上載者:User

標籤:mysql   myisam   innodb   

1.備份資料庫: mysqldump -u[user] -p[password] [databasename] > [dbfile.sql] # 備份資料庫。
2. /usr/local/mysql/bin/mysqladmin -u root -p shutdown # 停止資料庫 或者 service mysql stop。
3. InnoDB 表不支援全文檢索搜尋(fulltext search),那麼,記得要將備份出來的資料庫sql,刪掉有關 Fulltext 的索引。
4. cd /usr/local/mysql/support-files/ 找尋適合主機記憶體的設定檔案,必將設定檔案拷貝到 /etc/my.cnf。
5. vi /etc/my.cnf ,將以下幾項批註取消掉。以 my-large.cnf 為例。

innodb_data_file_path = ibdata1:10M:autoextend
  innodb_buffer_pool_size = 256M
  innodb_additional_mem_pool_size = 20M
  innodb_log_file_size = 5M
  innodb_log_buffer_size = 8M
  innodb_flush_log_at_trx_commit = 1
  innodb_lock_wait_timeout = 50
    加上 default-storage-engine=innodb
  加上這段之後,以後新增的資料表型態都即是 InnoDB,不然每次新增一次資料表,SQL 後面得加上 ENGINE=InnoDB; 

6 .將剛剛備份出來的sql,將ENGINE=MyISAM改成ENGINE=InnoDB。
7. /usr/local/mysql/bin/safe_mysqld --user=mysql &  ,或service mysql start 啟動資料庫
8. 建立一個新的資料庫(資料庫名稱跟備份出來的資料庫名稱一樣)。
9. mysql -u[user] -p[password] [database_name] < [dbfile] # 將改好的資料匯入資料庫中!

說明:
* 設定檔案的選擇是參照記憶體大小來選擇。
 my-huge.cnf - 1G~2G 、my-large.cnf - 512M 、 my-medium.cnf - 32M - 64M 、my-small.cnf <= 64M 。
 InnoDB:my-innodb-heavy-4G.cnf
* 假如不會將備份出來的資料庫改型態,那麼您可以用下面這個指令,直接改變資料表的型態。

ALTER TABLE [tablename] ENGINE=InnoDB 如有存放全文索引功能的話,轉換會失敗的。

* 如你有一批資料表要改,可以用下面的指令:
 mysql_convert_table_format [opt] --ENGINE=InnoDB dbname [tablename]
 但千萬注意不要改變 mysql 資料庫的資料型態,因為 mysql資料庫存放的是 MySQL 內部的管理資訊,所以必須保持 MyISAM 的格式。

* 加大 tablespace 空間
innodb_data_file_path = ibdata1:1G;ibdata2:1G:autoextend:max2G

 上面的意思是,tablespace 包含 ibdata1 & ibdata2 兩個檔案,若檔案不存在,則建立容量各為1G的檔案。一旦未來 InnoDB 需要,更多的空間,則 ibdata2 將每次自動增加 8MB,直到2G為止。


MySQL MyISAM 庫轉換為InnoDB的方法

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.