[dbfile.sql] # 備份數(shù)據(jù)庫。2. /usr/local/mysql/bin/mysqladmin -u root -p shutdown # ?..."/>
溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MySQL MyISAM 庫轉(zhuǎn)換為InnoDB的方法

發(fā)布時間:2020-08-05 17:42:01 來源:網(wǎng)絡(luò) 閱讀:1301 作者:rewiner22 欄目:數(shù)據(jù)庫

1.備份數(shù)據(jù)庫: mysqldump -u[user] -p[password] [databasename] > [dbfile.sql] # 備份數(shù)據(jù)庫。
2. /usr/local/mysql/bin/mysqladmin -u root -p shutdown # 停止數(shù)據(jù)庫 或者 service mysql stop。
3. InnoDB 表不支持全文搜索(fulltext search),那么,記得要將備份出來的數(shù)據(jù)庫sql,刪掉有關(guān) Fulltext 的索引。
4. cd /usr/local/mysql/support-files/ 找尋適合主機內(nèi)存的設(shè)定文件,必將設(shè)定文件拷貝到 /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
  加上這段之后,以后新增的數(shù)據(jù)表型態(tài)都即是 InnoDB,不然每次新增一次數(shù)據(jù)表,SQL 后面得加上 ENGINE=InnoDB; 

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

說明:
* 設(shè)定文件的選擇是參照內(nèi)存大小來選擇。
 my-huge.cnf - 1G~2G 、my-large.cnf - 512M 、 my-medium.cnf - 32M - 64M 、my-small.cnf <= 64M 。
 InnoDB:my-innodb-heavy-4G.cnf
* 假如不會將備份出來的數(shù)據(jù)庫改型態(tài),那么您可以用下面這個指令,
直接改變數(shù)據(jù)表的型態(tài)。

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

* 如你有一批數(shù)據(jù)表要改,可以用下面的指令:
 mysql_convert_table_format [opt] --
ENGINE=InnoDB dbname [tablename]
 但千萬注意不要改變 mysql 數(shù)據(jù)庫的數(shù)據(jù)型態(tài),因為 mysql數(shù)據(jù)庫存放的是 MySQL 內(nèi)部的管理信息,所以必須保持 MyISAM 的格式。

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

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


向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI