Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment précharger des tables dans le pool de mémoire tampon INNODB avec MySQL ?

Cela devrait vous donner une liste de requêtes à exécuter;)

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

Vous pouvez le mettre dans une procédure stockée et parcourir le jeu de résultats avec le curseur. Créez une instruction préparée à partir de chaque ligne et exécutez-la.