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 * FROM
tbl_name
Select * from
tbl_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 executed within the body of a 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 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, the results of a
SELECT query on a view is 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. Beginning with 5.1.17, prepared statements use the
query cache under certain conditions, which differ depending
on the preparation method:
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.
Before MySQL 5.1.21, 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). As of MySQL 5.1.21, this limitation is lifted
and prepared statments that contain parameter markers can
be cached because expansion directly substitutes the user
variable values.
A query cannot be cached if it contains any of the functions
shown in the following table:
It refers to tables in the mysql or
INFORMATION_SCHEMA 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 29, Connectors.
It uses TEMPORARY tables.
It does not use any tables.
It generates warnings.
The user has a column-level privilege for any of the
involved tables.
User Comments
Query caching is also not done in certain cases with transactions, see
http://www.mysqlperformanceblog.com/2008/01/29/how-mysql-query-cache-works-with-transactions/
Add your own comment.