FLUSH [LOCAL | NO_WRITE_TO_BINLOG] flush_option [, flush_option] ...
若是您想要清除MySQL使用的部份内部缓存,您应该使用FLUSH语句。要执行FLUSH,您必须拥有RELOAD权限。mysql
HOSTSsql
用于清空主机缓存表。若是有的主机更改了IP号或若是您获得了错误信息Host host_name is blocked,则您应该刷新主机表。当在链接到MySQL服务器时,若是对于一个给定的主机,接连出现错误“多于max_connect_errors”,此时,MySQL会假定出现了错误,并阻止主机后续的链接申请。刷新主机表容许主机尝试再次链接。请参见A.2.5节,“主机的host_name被屏蔽”。您可使用max_connect_errors=999999999启动mysqld,以免此错误信息。数据库
DES_KEY_FILE缓存
用于在服务器启动时,从采用--des-key-file选项指定的文件从新载入DES关键字。服务器
LOGSide
用于关闭并从新打开全部的日志文件。若是您已经指定了一个更新日志文件或一个二进制日志文件,同时没有扩展,则相对于前一个文件,日志文件的扩展号增长1。若是您在文件名称中使用了一个扩展,则MySQL会关闭并从新打开日志文件。在Unix中,当相mysqld服务器发送一个SIGHUP信号时,也会如此(例外状况是部分Mac OS X 10.3版本。在这些版本中,mysqld忽略SIGHUP和SIGQUIT)。spa
若是服务器使用--log-error选项,则FLUSH LOGS会致使错误日志被重命名(使用后缀-old),同时mysqld会建立一个新的空日志文件。若是没有给定--log-error选项,则不会进行重命名。调试
PRIVILEGES日志
用于从mysql数据库中的受权表从新载入权限。orm
QUERY CACHE
对查询缓存进行整理碎片,以更好得利用存储器。与RESET QUERY CACHE不一样,本语句不会从缓存中取消任何查询。
STATUS
用于把多数状态变量从新设置为零。只在当调试查询时,您才应该使用此项。请参见1.7.1.3节,“如何通报缺陷和问题”。
{TABLE | TABLES} [tbl_name [, tbl_name] ...]
当没有表被命名时,关闭全部打开的表,并迫使全部正在使用的表关闭。这也会刷新查询缓存。此项含有一个或多个表名称,只刷新给定的表。和RESET QUERY CACHE语句同样,FLUSH TABLES还会取消来自查询缓存的全部查询结果。
TABLES WITH READ LOCK
对于全部带读取锁定的数据库,关闭全部打开的表,并锁定全部的表,直到您执行UNLOCK TABLES为止。若是您拥有一个能够及时进行快照的文件系统,好比Veritas,则这是进行备份的很是方便的方法。
USER_RESOURCES
用于把全部每小时用户资源从新设置为零。这可使已经达到了每小时链接、查询或更新限值的客户端马上从新恢复活性。FLUSH USER_RESOURCES不适用于同时链接的最大限值。请参见13.5.1.3节,“GRANT和REVOKE语法”。
FLUSH语句被写入二进制日志,除非使用了自选的NO_WRITE_TO_BINLOG关键字(或其别名LOCAL)。 注释:在任何状况下,FLUSH LOGS, FLUSH MASTER, FLUSH SLAVE和FLUSH TABLES WITH READ LOCK都不会被记入日志,由于若是它们被复制到一个从属服务器上,会致使出现问题。
您也可使用flush-hosts, flush-logs, flush-privileges, flush-status或flush-tables命令访问含有mysqladmin应用程序的语句。