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] #將改好的數據匯入數據庫中!

創新互聯于2013年開始,先為潮安等服務建站,潮安等地企業,進行企業商務咨詢服務。為潮安企業網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。
說明:
*設定文件的選擇是參照內存大小來選擇。
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為止。
當前文章:MySQLMyISAM庫轉換為InnoDB的方法
地址分享:http://www.js-pz168.com/article28/jeedcp.html
成都網站建設公司_創新互聯,為您提供網站排名、網站內鏈、電子商務、定制網站、用戶體驗、面包屑導航
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯