This section describes how the query cache works when it is operational. Section 5.13.3, “Query Cache Configuration”, describes how to control whether it is operational.
Incoming queries are compared to those in the query cache before parsing, so the following two queries are regarded as different by the query cache:
SELECT * FROMtbl_nameSelect * fromtbl_name
Queries must be exactly the same (byte for byte) to be seen as identical. In addition, query strings that are identical may be treated as different for other reasons. Queries that use different databases, different protocol versions, or different default character sets are considered different queries and are cached separately.
The cache is not used for queries of the following types:
Queries that are a subquery of an outer query
Queries executed within the body of a stored procedure, stored function, trigger, or event
Before a query result is fetched from the query cache, MySQL
checks that the user has SELECT privilege for
all databases and tables involved. If this is not the case, the
cached result is not used.
If a query result is returned from query cache, the server
increments the Qcache_hits status variable,
not Com_select. See
Section 5.13.4, “Query Cache Status and Maintenance”.
If a table changes, all cached queries that use the table become
invalid and are removed from the cache. This includes queries
that use MERGE tables that map to the changed
table. A table can be changed by many types of statements, such
as INSERT, UPDATE,
DELETE, TRUNCATE,
ALTER TABLE, DROP TABLE,
or DROP DATABASE.
The query cache also works within transactions when using
InnoDB tables.
In MySQL 5.1, queries generated by views are cached.
The query cache works for SELECT SQL_CALC_FOUND_ROWS
... queries and stores a value that is returned by a
following SELECT FOUND_ROWS() query.
FOUND_ROWS() returns the correct value even
if the preceding query was fetched from the cache because the
number of found rows is also stored in the cache. The
SELECT FOUND_ROWS() query itself cannot be
cached.
Before MySQL 5.1.17, prepared statements do not use the query cache. As of 5.1.17, prepared statements use the query cache under certain conditions, which differ depending on the preparation method:
Statements that are issued via the binary protocol using
mysql_stmt_prepare() and
mysql_stmt_execute(). See
Section 24.2.4, “C API Prepared Statements”.
For a prepared statement executed via the binary protocol,
comparison with statements in the query cache is based on
the text of the statement after expansion of
? parameter markers. The statement is
compared only with other cached statements that were
executed via the binary protocol. That is, for query cache
purposes, statements issued via the binary protocol are
distinct from statements issued via the text protocol.
Statements that are issued via the text (non-binary)
protocol using PREPARE and
EXECUTE. See Section 13.7, “SQL Syntax for Prepared Statements”.
These are denoted SQL PS statements here.
For a prepared statement executed via
PREPARE and EXECUTE,
it is not cached if it contains any ?
parameter markers. In that case, the statement after
parameter expansion contains references to user variables,
which prevents caching, even for non-prepared statements. If
the statement contains no parameter markers, the statement
is compared with statements in the query cache that were
executed via the text protocol (that is, it is compared with
other SQL PS statements and non-prepared statements).
A query cannot be cached if it contains any of the functions shown in the following table:
BENCHMARK() |
CONNECTION_ID() |
CURDATE() |
CURRENT_DATE() |
CURRENT_TIME() |
CURRENT_TIMESTAMP() |
CURTIME() |
DATABASE() |
ENCRYPT() with one parameter |
FOUND_ROWS() |
GET_LOCK() |
LAST_INSERT_ID() |
LOAD_FILE() |
MASTER_POS_WAIT() |
NOW() |
RAND() |
RELEASE_LOCK() |
SYSDATE() |
UNIX_TIMESTAMP() with no parameters |
USER() |
A query also is not cached under these conditions:
It refers to user-defined functions (UDFs) or stored functions.
It refers to user variables.
It refers to tables in the mysql system
database.
It is of any of the following forms:
SELECT ... IN SHARE MODE SELECT ... FOR UPDATE SELECT ... INTO OUTFILE ... SELECT ... INTO DUMPFILE ... SELECT * FROM ... WHERE autoincrement_col IS NULL
The last form is not cached because it is used as the ODBC workaround for obtaining the last insert ID value. See the MyODBC section of Chapter 25, Connectors.
It was issued as a prepared statement, even if no placeholders were employed. For example, the query used here is not cached:
char *my_sql_stmt = "SELECT a, b FROM table_c"; /* ... */ mysql_stmt_prepare(stmt, my_sql_stmt, strlen(my_sql_stmt));
It uses TEMPORARY tables.
It does not use any tables.
The user has a column-level privilege for any of the involved tables.

User Comments
Add your own comment.