How Do I Create a MySQL Table That Uses the InnoDB Storage Engine?

Home » Knowledge Base » Databases » How Do I Create a MySQL Table That Uses the InnoDB Storage Engine?

MySQL databases, like any other software product, are constantly being developed and new features are being added all the time. Popular CMSs like WordPress and Joomla are quick to adopt these new database features in order to improve security, reliability, and performance. In this article, we will take a look at one of the most important aspects of a MySQL database – its storage engine. We will discuss what a storage engine is and how to change the storage engine for your MySQL database tables.

 

What Is a Database Storage Engine?

At its most basic level, a database storage engine is a program that directly manipulates the information stored within the database. The storage engine accepts commands through its programming interface (API). These commands instruct the engine to create, read, update or delete one or more database entries.

 

What Is the Default Storage Engine?

Currently, if you start creating new tables in your database without specifying a storage engine, the MyISAM storage engine will be used by default. The good news is that if you later realize that you need a different engine for your table, you will be able to change it without any data loss.

 

How Can I Discover Which Storage Engine Is Used on a Particular Table?

If you are not sure which storage engine is being used in your table, you can easily find out through phpMyAdmin or by sending an SQL query. We will cover both approaches.

To discover which storage engine you are using through phpMyAdmin’s interface, follow these steps:

  1. Navigate to the phpMyAdmin utility in your web browser.
  2. If necessary, log in using your database credentials (not your hosting account credentials).
  3. Click on the table name which you would like to inspect from the list of the left.
  4. Switch to the Operations tab.
  5. You will find your Storage Engine listed in the Table options section.
phpMyAdmin lists the storage engine that is in use right inside of the Operations tab.
phpMyAdmin lists the storage engine that is in use right inside of the Operations tab.

If you are in a hurry or just prefer to send SQL commands manually, you can jump to the SQL tab of phpMyAdmin (or create a script that connects to your database) and run the following query (make sure that you replace table-name with the actual name of the table you are querying):

SHOW TABLE STATUS WHERE `Name` = 'table-name';

The results will be presented in a table format. The storage engine will be listed in the Engine column, as shown below:

The results of the SHOW TABLE STATUS query. The Storage Engine type is highlighted.
The results of the SHOW TABLE STATUS query. The Storage Engine type is highlighted.

 

How Do I Create a MySQL Table That Uses the InnoDB Storage Engine?

If you know that your site will be requiring the InnoDB storage engine, you can easily create your new tables using InnoDB from the onset. The InnoDB engine is available on all of our paid hosting plans and even on our free hosting service. In fact, there are two different ways you can set your storage engine, depending on how you create your table – via the phpMyAdmin interface or using an SQL command.

You can create a table with InnoDB as its storage engine via phpMyAdmin’s interface by following the steps below:

  1. Navigate to the phpMyAdmin utility in your web browser.
  2. If necessary, log in using your database credentials (not your hosting account credentials).
  3. Click on the database name from the list of the left in order to indicate where you would like to include the new table.
  4. In the Create table section, pick a name for your new table and choose the number of columns.
  5. Press the Go button in order to start creating your new table.
Creating a new table through the phpMyAdmin interface.
Creating a new table through the phpMyAdmin interface.
  1. You will be taken to the table creation interface. Locate the Storage Engine section and make sure that InnoDB is selected from the dropdown.
  2. Finish creating your table by customizing each column. When done, press the Save button.
Creating a table with InnoDB as the storage engine is as simple as choosing InnoDB from the Storage Engine dropdown menu.
Creating a table with InnoDB as the storage engine is as simple as choosing InnoDB from the Storage Engine dropdown menu.

If you prefer to use your own SQL statements when creating a new table, simply make sure to append ENGINE=InnoDB to your statement as is shown in the example below:

CREATE TABLE new-table (a INT NOT NULL, b CHAR(10)) ENGINE=InnoDB;


How Do I Convert an Existing MySQL Table From the MyISAM Storage Engine to InnoDB?

You may be surprised to learn that it is indeed possible to change the storage engine for an existing MySQL table. And best of all – your data will remain safe. Converting your table from MyISAM to InnoDB is a straightforward process that can be achieved via both phpMyAdmin and an SQL query.

To convert your storage engine via phpMyAdmin, follow the steps below:

  1. Navigate to the phpMyAdmin utility in your web browser.
  2. If necessary, log in using your database credentials (not your hosting account credentials).
  3. Click on the table name which you would like to modify from the list on the left.
  4. Switch to the Operations tab.
  5. Locate the Table options section and use the dropdown menu to Storage Engine to change your storage engine from MyISAM to InnoDB.
  6. Once you have made your selection, press the Go button at the bottom of the Table options section in order to save your changes.
phpMyAdmin allows you to update the storage engine that is in use right inside of the Operations tab.
phpMyAdmin allows you to update the storage engine that is in use right inside of the Operations tab.

As an alternative, you can also execute an ALTER TABLE SQL statement in order to start using a different storage engine (make sure to replace table-name with the actual name of the table you are modifying):

ALTER TABLE `table-name` ENGINE = InnoDB;

The only caveat that should be mentioned is that some storage engines have features that are not found in other storage engines. So if you convert from a storage engine with more features to one with fewer, you may lose some of these extra customizations. Continue reading in order to find the most notable differences between the MyISAM and InnoDB storage engines.

 

What Are the Main Differences Between the InnoDB and MyISAM Storage Engines?

While in most cases your website software will dictate the type of storage engine you should use, some packages support both types of storage engine and it will be ultimately up to you which storage engine you will use. Below is a brief comparison between the two most popular storage engines InnoDB and MyISAM.

Overall, InnoDB is the more advanced storage engine. It uses a relational base design that enables features like transactions, foreign keys, and row locking. Consequently, you will experience better performance if your project executes a lot of inserts, updates, and deletes. InnoDB is also geared towards large databases.

Conversely, MyISAM excels in terms of performance if your project mainly reads from the database without modifying any data. MyISAM is also the preferred storage engine for smaller projects.

 

Conclusion

The ability to quickly switch between the different storage engines gives you the flexibility to adapt your database to your project’s needs as it grows over time. And since your data is automatically preserved with each storage engine change, you can experiment with different storage engines with no risk and minimal effort.

Was this post helpful?

i

Relevant tags:

Connect

Latest posts:

How to Install MediaWiki

You can quickly install MediaWiki on any of the AwardSpace web hosting plans. This includes our free web hosting, shared hosting, as well as advanced services such as semi-dedicated hosting and VPS hosting. You can install MediaWiki in a matter of minutes, whichever...

How to Install an Elgg Theme

After you have installed Elgg core and logged in to the admin dashboard, you can search for themes that can help you customize your new website. Elgg themes are a set of files that help you customize the appearance of your website. Via themes, you can modify website...

How to Log in to Elgg

After you install Elgg, it is time to log in to the CMS, so you can start working on your Elgg website. To log in, you should load the Elgg login page and type in your credentials to access the platform’s admin dashboard. In the following paragraphs, we share how to...

How to Install Elgg

You can quickly install Elgg with any of the AwardSpace web hosting plans. You can use our free web hosting, shared web hosting, or advanced hosting plans such as semi-dedicated hosting and VPS hosting.   How to Install Elgg To install Elgg, you should first sign...

How to Change the PHP Timezone

Setting the correct timezone in PHP is crucial for ensuring that date and time functions in your scripts operate accurately. AwardSpace offers a range of hosting plans that provide easy management of PHP settings, including timezone configuration. This article will...



Create a website for free!


Free forever

Our Support Team is Here to Help

 

If you need any questions answered, don't hesitate and contact us. Click the button below and follow the instructions. You can expect an answer within an hour.

 

Contact AwardSpace

 

iNewest knowledge base articles

How to Install MediaWiki

You can quickly install MediaWiki on any of the AwardSpace web hosting plans. This includes our free web hosting, shared hosting, as well as advanced services such as semi-dedicated hosting and VPS hosting. You can install MediaWiki in a matter of minutes, whichever...

How to Install an Elgg Theme

After you have installed Elgg core and logged in to the admin dashboard, you can search for themes that can help you customize your new website. Elgg themes are a set of files that help you customize the appearance of your website. Via themes, you can modify website...

How to Log in to Elgg

After you install Elgg, it is time to log in to the CMS, so you can start working on your Elgg website. To log in, you should load the Elgg login page and type in your credentials to access the platform’s admin dashboard. In the following paragraphs, we share how to...

How to Install Elgg

You can quickly install Elgg with any of the AwardSpace web hosting plans. You can use our free web hosting, shared web hosting, or advanced hosting plans such as semi-dedicated hosting and VPS hosting.   How to Install Elgg To install Elgg, you should first sign...

How to Change the PHP Timezone

Setting the correct timezone in PHP is crucial for ensuring that date and time functions in your scripts operate accurately. AwardSpace offers a range of hosting plans that provide easy management of PHP settings, including timezone configuration. This article will...

How to Disable PHP Error Messages

When running a PHP-based website in a production environment, it's crucial to disable PHP error messages to prevent sensitive information from being exposed to users. AwardSpace offers a variety of hosting plans tailored to different needs, all of which support...

Even more web tutorials

Check out our web hosting knowledge base and the WordPress tutorials to learn more, and be better prepared for your website creation and maintenance journey.