写点什么

MySQL 查询重写插件

作者:TimeFriends
  • 2022 年 8 月 31 日
    北京
  • 本文字数:1240 字

    阅读完需:约 4 分钟

查询重写插件

从 MySQL 5.7.6 开始,MySQL Server 支持查询重写插件,可以在服务器执行之前检查并可能修改服务器接收的语句。

以下是官方文档介绍:

预解析重写插件具有以下特点:

1.该插件允许在服务器处理之前重写到达服务器的 SQL 语句。

2.该插件接收一个语句字符串,并可能返回一个不同的字符串。

后解析查询重写插件具有以下特征:

1.该插件支持基于解析树的语句重写。

2.服务器解析每个语句并将其解析树传递给插件,插件可以遍历树。插件可以将原始树返回到服务器以进行进一步处理,或者构造不同的树并返回该树。

通俗来讲,是指该插件支持两种重写方式,一种是在语法解析之前,直接修改 SQL 字符串,一种是在语法解析之后,通过操控语法解析树来进行重写。这个特性还是非常有用的,例如错误的上线了某个 SQL,但由于无法走到索引导致全库查询; 或者你可能使用某个第三方的已编译好的软件,但 SQL 可能执行错误,你又无法直接修改应用,这个特性将会非常有用,还可以去编写符合用户要求的插件。

安装或卸载

最简单的安装过程如下:



可以发现,在数据库中多增加了一个库 query_rewrite,查看该数据库:



重写器查询重写插件过程

将规则添加到 rewrite_rules 表中不足以使 Rewriter 插件使用该规则。还必须调用 flush_rewrite_rules()以将表内容加载到插件内存缓存中:

Rewriter 插件操作使用存储过程将规则表加载到其内存缓存中,在正常操作下,用户仅调用 flush_rewrite_rules()从而将 rewrite_rules 表的内容加载到 Rewriter 内存高速缓存中。加载表后,它还会清除查询缓存。

当修改规则表后,需要重新调用此过程以使插件从新表内容更新其缓存:



使用重写插件中定义的语句模式查询相应记录:



通过使用 explain 语句查看,当前 SQL 已经使用了索引



重写插件操作信息

该 Rewriter 插件通过几个状态变量提供有关其操作的信息:



有关这些变量的说明:

Rewriter_number_loaded_rules:成功从 rewrite_rules 表中加载到内存中以供 Rewriter 插件使用的重写插件重写规则的数量。

Rewriter_number_reloads:rewrite_rules 被加载到 Rewriter 插件缓存中的次数。

Rewriter_number_rewritten_queries:Rewriter 查询重写插件自加载以来重写的查询数 。

Rewriter_reload_error:是否在最近将 rewrite_rules 表加载到 Rewriter 插件使用的内存高速缓存中时发生错误 。如果值为 OFF,则不会发生错误。如果值为,则 ON 发生错误;检查表的 message 列 rewriter_rules 是否有错误消息。

通过调用 flush_rewrite_rules()存储过程加载规则表时 ,如果某些规则发生错误,则该 CALL 语句会产生错误,并且该插件会将 Rewriter_reload_error 状态变量设置为 ON:



在这种情况下,请检查 rewrite_rules 表中是否包含非 NULL message 列值的行,以查看存在的问题。

重写器插件使用字符集

当 rewrite_rules 表加载到 Rewriter 插件中时,插件使用 character_set_client 系统变量的当前全局值来解释语句 。如果 character_set_client 随后更改全局 值,则必须重新加载规则表。

客户端的会话 character_set_client 值必须 与加载规则表时的全局值相同,否则规则匹配将不适用于该客户端。

用户头像

TimeFriends

关注

加油! 年轻人! 2022.08.02 加入

这里没有天赋异禀,也没有天资聪颖,只有每天的陪伴。万物瞬息万变,但唯一不变的只有变化。抓住变化的根本,以时间为伍,以坚持为伴,做时间的朋友。

评论

发布
暂无评论
MySQL查询重写插件_8月月更_TimeFriends_InfoQ写作社区