mysql temporary table vs memory table
Temporary tables are tables with limited scope, and memory tables are tables with different storage methods. Temporary tables are visible in the current session and are automatically deleted after the connection is disconnected. Various storage engines can be used, which are suitable for saving intermediate results and avoiding repeated calculations; 1. Temporary tables support indexing, and multiple sessions can create tables with the same name without affecting each other; 2. The memory table uses the MEMORY engine, and the data is stored in memory, and the restart is lost, which is suitable for cache small data sets with high frequency access; 3. The memory table supports hash indexing, and does not support BLOB and TEXT types, so you need to pay attention to memory usage; 4. The life cycle of the temporary table is limited to the current session, and the memory table is shared by all connections. When choosing, it should be decided based on whether the data is private, whether high-speed access is required and whether it can tolerate loss.

There are temporary tables and memory tables in MySQL, which are easy to be confused when many people use them. In fact, they are two different things and the problems they solve are also different. Simply put: a temporary table is a table with a limited scope of function, while a memory table is a table with different storage methods .

The following is a few common usage scenarios to talk about their differences and application.
What is a temporary table?
A temporary table is a table structure that is only visible in the current session. Once the connection is disconnected, the table will be automatically deleted. It can be used with any storage engine, such as InnoDB, MyISAM, or Memory.

Common uses:
- Save temporary data in the middle of complex query
- Avoid repeated calculations and improve performance
- Used for intermediate results in stored procedures or functions
Recommended usage:
- If you only need a "intermediate table" for the current operation and do not want to affect other users, use temporary tables
- You can create indexes or operate like normal tables
- Multiple sessions can create temporary tables with the same name without affecting each other
Example statement:
CREATE TEMPORARY TABLE temp_users (
id INT,
name VARCHAR(100)
);What is a memory table?
Memory Table, also known as HEAP table, is a table that stores data in memory and uses the MEMORY storage engine. It reads and writes quickly, but data is lost after restarting.

Common uses:
- Caches small datasets with high frequency access
- Speed up certain operations as temporary cache
- Used for fast read and write scenarios such as statistics and counting
Recommended usage:
- Used when the data is not large and you are not afraid of losing it
- Supports hash index, suitable for point-checking
- BLOB and TEXT type fields are not supported
- Pay attention to memory usage and don't crash the server
Example statement:
CREATE TABLE cache_data (
key_name VARCHAR(50) PRIMARY KEY,
value TEXT
) ENGINE=MEMORY;Temporary table vs memory table: key differences
| characteristic | Temporary table | Memory table |
|---|---|---|
| life cycle | Destroy the current session as soon as it is finished | Data is lost with service restart |
| Storage Engine | Multiple engines can be specified (default InnoDB) | Fixed as MEMORY engine |
| Whether it is persistent | no | no |
| Whether to share | No (each session is independent) | Yes (all connections are accessible) |
| Applicable scenarios | Intermediate data processing, private data storage | Fast cache, high-frequency access to data |
How to choose in practical applications?
If you just want to save some intermediate results during SQL execution and don't want others to see it, then use temporary tables ;
If there is a set of data that you want to keep it alive and access it quickly and you are not afraid of reboot loss, you can consider using memory tables .
Of course, sometimes you can also use it in combination, such as using temporary tables for intermediate processing, and then put the results in the memory table for subsequent calls.
Basically, these are all. Both types of tables have their own positioning. Understand their essence so that they will not make mistakes when used.
The above is the detailed content of mysql temporary table vs memory table. For more information, please follow other related articles on the PHP Chinese website!
Hot AI Tools
Undress AI Tool
Undress images for free
Undresser.AI Undress
AI-powered app for creating realistic nude photos
AI Clothes Remover
Online AI tool for removing clothes from photos.
Clothoff.io
AI clothes remover
Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!
Hot Article
Hot Tools
Notepad++7.3.1
Easy-to-use and free code editor
SublimeText3 Chinese version
Chinese version, very easy to use
Zend Studio 13.0.1
Powerful PHP integrated development environment
Dreamweaver CS6
Visual web development tools
SublimeText3 Mac version
God-level code editing software (SublimeText3)
How to add a primary key to an existing table in MySQL?
Aug 12, 2025 am 04:11 AM
To add a primary key to an existing table, use the ALTERTABLE statement with the ADDPRIMARYKEY clause. 1. Ensure that the target column has no NULL value, no duplication and is defined as NOTNULL; 2. The single-column primary key syntax is ALTERTABLE table name ADDPRIMARYKEY (column name); 3. The multi-column combination primary key syntax is ALTERTABLE table name ADDPRIMARYKEY (column 1, column 2); 4. If the column allows NULL, you must first execute MODIFY to set NOTNULL; 5. Each table can only have one primary key, and the old primary key must be deleted before adding; 6. If you need to increase it yourself, you can use MODIFY to set AUTO_INCREMENT. Ensure data before operation
Explain database indexing strategies (e.g., B-Tree, Full-text) for a MySQL-backed PHP application.
Aug 13, 2025 pm 02:57 PM
B-TreeindexesarebestformostPHPapplications,astheysupportequalityandrangequeries,sorting,andareidealforcolumnsusedinWHERE,JOIN,orORDERBYclauses;2.Full-Textindexesshouldbeusedfornaturallanguageorbooleansearchesontextfieldslikearticlesorproductdescripti
How to back up a database in MySQL
Aug 11, 2025 am 10:40 AM
Using mysqldump is the most common and effective way to back up MySQL databases. It can generate SQL scripts containing table structure and data. 1. The basic syntax is: mysqldump-u[user name]-p[database name]>backup_file.sql. After execution, enter the password to generate a backup file. 2. Back up multiple databases with --databases option: mysqldump-uroot-p--databasesdb1db2>multiple_dbs_backup.sql. 3. Back up all databases with --all-databases: mysqldump-uroot-p
How to change the GROUP_CONCAT separator in MySQL
Aug 22, 2025 am 10:58 AM
You can customize the separator by using the SEPARATOR keyword in the GROUP_CONCAT() function; 1. Use SEPARATOR to specify a custom separator, such as SEPARATOR'; 'The separator can be changed to a semicolon and plus space; 2. Common examples include using the pipe character '|', space'', line break character '\n' or custom string '->' as the separator; 3. Note that the separator must be a string literal or expression, and the result length is limited by the group_concat_max_len variable, which can be adjusted by SETSESSIONgroup_concat_max_len=10000; 4. SEPARATOR is optional
What is the difference between UNION and UNION ALL in MySQL?
Aug 14, 2025 pm 05:25 PM
UNIONremovesduplicateswhileUNIONALLkeepsallrowsincludingduplicates;1.UNIONperformsdeduplicationbysortingandcomparingrows,returningonlyuniqueresults,whichmakesitsloweronlargedatasets;2.UNIONALLincludeseveryrowfromeachquerywithoutcheckingforduplicates,
How to lock tables in MySQL
Aug 15, 2025 am 04:04 AM
The table can be locked manually using LOCKTABLES. The READ lock allows multiple sessions to read but cannot be written. The WRITE lock provides exclusive read and write permissions for the current session and other sessions cannot read and write. 2. The lock is only for the current connection. Execution of STARTTRANSACTION and other commands will implicitly release the lock. After locking, it can only access the locked table; 3. Only use it in specific scenarios such as MyISAM table maintenance and data backup. InnoDB should give priority to using transaction and row-level locks such as SELECT...FORUPDATE to avoid performance problems; 4. After the operation is completed, UNLOCKTABLES must be explicitly released, otherwise resource blockage may occur.
How to select data from a table in MySQL?
Aug 19, 2025 pm 01:47 PM
To select data from MySQL table, you should use SELECT statement, 1. Use SELECTcolumn1, column2FROMtable_name to obtain the specified column, or use SELECT* to obtain all columns; 2. Use WHERE clause to filter rows, such as SELECTname, ageFROMusersWHEREage>25; 3. Use ORDERBY to sort the results, such as ORDERBYageDESC, representing descending order of age; 4. Use LIMIT to limit the number of rows, such as LIMIT5 to return the first 5 rows, or use LIMIT10OFFSET20 to implement paging; 5. Use AND, OR and parentheses to combine
How to use the IN operator in MySQL?
Aug 12, 2025 pm 03:46 PM
TheINoperatorinMySQLchecksifavaluematchesanyinaspecifiedlist,simplifyingmultipleORconditions;itworkswithliterals,strings,dates,andsubqueries,improvesqueryreadability,performswellonindexedcolumns,supportsNOTIN(withcautionforNULLs),andcanbecombinedwith


