官术网_书友最值得收藏!

Migrating a table from MyISAM to Aria

MariaDB ships with the MyISAM and Aria storage engines, among many others. The main difference between these two is that Aria is crash safe, whereas MyISAM is not. Being crash safe means that an Aria table can recover from catastrophic power loss or other unexpected failures in a much better way than a MyISAM table can. If we use MyISAM tables, an easy upgrade is to convert them to Aria tables.

Getting ready

Import the ISFDB database as described in the Importing the data exported by mysqldump recipe in this chapter.

How to do it...

  1. Open the mysql command-line client and connect to the isfdb database.
  2. Run the following command line:
    ALTER TABLE authors ENGINE=Aria;
    
  3. The ALTER command will then change the table so that it uses the Aria storage engine.
  4. After it has finished, a message similar to the following will be displayed:
    Query OK, 110829 rows affected (3.14 sec) 
    Records: 110829 Duplicates: 0 Warnings: 0 
    
  5. If our system is older or is under heavy load and it takes longer than 5 seconds for ALTER TABLE to complete, we'll see a progress message letting us know how much of the task has been completed, updated every 5 seconds, until the task is finished.

How it works...

The ALTER TABLE command changes a table in two stages. First, it creates a new table identical in every way to the old table, except that the new table has the changes specified by the command. In our case, the only change is to use the Aria storage engine instead of the MyISAM storage engine. Then, the command copies all of the data to the new table.

In the second stage, ALTER TABLE removes the old table and renames the new table with the name of the old table.

On a table like authors that only has around a hundred thousand rows, the conversion is quick and easy; however, on a table with several billion rows, the conversion process will take significantly longer.

See also

主站蜘蛛池模板: 宁化县| 平凉市| 赤水市| 闵行区| 新余市| 宜黄县| 湖南省| 出国| 惠东县| 寿宁县| 盐源县| 吉安市| 长兴县| 普定县| 松滋市| 白河县| 临沭县| 台北县| 乐亭县| 固镇县| 新化县| 天全县| 广安市| 和顺县| 新乡市| 平邑县| 霍州市| 永登县| 金华市| 扎鲁特旗| 井冈山市| 若尔盖县| 蓬安县| 商洛市| 南召县| 阳曲县| 灵台县| 井冈山市| 泸水县| 永平县| 建湖县|