Skip to main content

Storage Engines



          When creating a table in MySQL, the storage engine that will be used has to be chosen.  If one is not chosen, MySQL uses the default storage engine chosen in the configuration of the server.  MySQL supports several storage engines that act as handlers for different table types. MySQL storage engines include both those that handle transaction-safe tables and those that handle non-transaction-safe tables. There are numerous storage engines that MySQL supports; however the most common storage types that are used with PHP are listed below: 











•  MyISAM -
                    This storage engine is supported in all MySQL configurations and is the default storage engine for all new tables created (when a specific storage engine is not assigned) in the majority of default installations.  This storage engine manages non-transactional tables.  It provides high-speed storage and retrieval, as well as fulltext searching capabilities.  MyISAM is a disk based storage engine.  Aiming for very low overhead, it does not support transactions. 


•  InnoDB -
                    InnoDB is also disk based, but offers versioned, fully ACID transactional capabilities. InnoDB requires more disk space than MyISAM to store its data, and this increased overhead is compensated by more aggressive use of memory caching, in order to attain high speeds.  InnoDB is included by default in all MySQL 5.0 binary distributions. 


•  Memory (formerly called "Heap") - 


                    This storage engine provides in-memory (utilizes only RAM) tables.  Special algorithms are used that make optimal use of this environment. It is very fast. Like MyISAM, the Memory storage engine handles non-transactional tables, and is also included in MySQL by default.  


•  NDB - 
                This is the MySQL Cluster Storage engine which connects to a cluster of nodes, offering high availability through redundancy, high performance through fragmentation (partitioning) of data across multiple node groups, and excellent scalability through the combination of these two. Prior to MySQL 5.1, NDB used main-memory only, with logging to disk. 



Table Limits 

                  The MySQL server has no limits overall on the number of tables that can be created in a database; however, there are limits within the storage engine type itself or on in the operating system that contains the MySQL server.  InnoDB, for example, limits the number of tables that can be created for the entire database to 2 million tables.  This means that one database server can not contain more the 2 million tables across one database or multiple databases.  This is because all InnoDB tables are stored in a central files in the operating system and not separated out by database.  MyISAM tables on the other hand do not have any such limitations; however, the operating system can oppose limits on the number of files that can be stored on disk or in an individual sub-directory. 


Comments

Popular posts from this blog

PHP INTRODUCTION

                     PHP  (recursive acronym for  PHP: Hypertext Preprocessor ) is a widely-used open source general-purpose scripting language that is especially suited for web development and can be embedded into HTML. PHP stands for  P HP:  H ypertext  P reprocessor PHP is a server-side scripting language, like ASP PHP scripts are executed on the server PHP supports many databases (MySQL, Informix, Oracle, Sybase, Solid, PostgreSQL, Generic ODBC, etc.) PHP is an open source software PHP is free to download and use Why PHP? PHP runs on different platforms (Windows, Linux, Unix, etc.) PHP is compatible with almost all servers used today (Apache, IIS, etc.) PHP is FREE to download from the official PHP resource:  www.php.net PHP is easy to learn and runs efficiently on the server side What can PHP do? Anything. PHP is mainly focused on server-side scripting, so you can do anything any other CGI program can do, such as collect form data, generate dynam

MySQL General Architecture

        MySQL operates in a networked environment using a client/server architecture. In other words, a central  program acts as a server, and various client programs connect to the server to make requests. A MySQL  installation has the following major components: MySQL Server, Client programs and MySQL non client  utilities.  MySQL Server MySQL Server, or mysqld, is the database server program. The server manages access to the actual  database (schema) on disk and in memory. MySQL Server is multi-threaded and supports many  simultaneous client connections. Clients can connect via several connection protocols. For managing  database contents, the MySQL server features a modular architecture that supports multiple storage engines  that handle different types of tables (for example, it supports both transactional and non-transactional  tables). Keep in mind the difference between a server and a host. The server is software (the MySQL server  program mysqld). Server characteristi