我有一个使用MySQL的电子商务应用程序,我希望它更快。当在之前访问过的网站上访问部件#时,部件会快速加载,因为所有必需的数据已经在INNODB缓冲池中。但是,如果之前从未加载过部分#,那么该数据还不在缓冲池中,因此需要从磁盘读取,这很慢。我将INNODB缓冲池设置为2GB,整个数据库只有350MB左右,因此有足够的空间在缓冲池中加载整个数据库。我可以从INNODB统计数据中看到,目前只使用了大约一半的缓冲池。
我发现了预加载数据的引用,也称为“预热”缓冲池,例如Quickly preloading Innodb tables in the buffer pool或mysqldump.azundris.com/archives/70-Innodb-cache-preloading-使用-blackhole.html。该策略基本上涉及强制对每个表进行表扫描,因为MySQL没有预加载数据的本机方式。
我不想手动创建一个列出数据库中每个表的脚本,而且必须这样做。如何创建一个脚本,并自动为每个表执行选择,并自动选取一个非索引列以执行表扫描?
答案 0 :(得分:25)
这应该为您提供要运行的查询列表;)
SELECT
CONCAT('SELECT ',MIN(c.COLUMN_NAME),' FROM ',c.TABLE_NAME,' WHERE ',MIN(c.COLUMN_NAME),' IS NOT NULL')
FROM
information_schema.COLUMNS AS c
LEFT JOIN (
SELECT DISTINCT
TABLE_SCHEMA,TABLE_NAME,COLUMN_NAME
FROM
information_schema.KEY_COLUMN_USAGE
) AS k
USING
(TABLE_SCHEMA,TABLE_NAME,COLUMN_NAME)
WHERE
c.TABLE_SCHEMA = 'yourDatabase'
AND k.COLUMN_NAME IS NULL
GROUP BY
c.TABLE_NAME
您可以将其放入存储过程,并使用光标检查结果集。从每一行创建一个准备好的语句,然后执行。
答案 1 :(得分:0)
此查询将返回数据库中的表名,因此您无需手动输入:
SELECT TABLE_NAME FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'database name'
然后为每个表名强制表扫描。