openGauss学习笔记-300 openGauss AI特性-AI4DB数据库自治运维-DBMind的AI子功能-SQL Rewriter SQL语句改写

118 阅读3分钟

openGauss学习笔记-300 openGauss AI特性-AI4DB数据库自治运维-DBMind的AI子功能-SQL Rewriter SQL语句改写300.1 概述300.2 使用指导300.2.1 前提条件300.2.2 使用方法示例300.3 获取帮助300.4 命令参考300.5 常见问题处理

openGauss学习笔记-300 openGauss AI特性-AI4DB数据库自治运维-DBMind的AI子功能-SQL Rewriter SQL语句改写

300.1 概述

SQL Rewriter是一个SQL改写工具,根据预先设定的规则,将查询语句转换为更为高效或更为规范的形式,使得查询效率得以提升。

img 说明:

  • 本功能不适用包含子查询的语句;
  • 本功能只支持SELECT语句和DELETE对整个表格删除的语句;
  • 本功能包含12个改写规则,对不符合改写规则的语句,不会进行处理;
  • 本功能会对原始查询语句和改写后语句进行屏幕输出,不建议对包含涉敏感信息的SQL语句进行改写;
  • union转union all规则避免了去重,从而提升了查询性能,所得结果有可能存在冗余;
  • 语句中如包含‘order by’+ 指定列名或‘group by’+ 指定列名,无法适用SelfJoin规则。

300.2 使用指导

300.2.1 前提条件

数据库状态正常、连接正常。

300.2.2 使用方法示例

以tpcc数据库为例:

gs_dbmind component sql_rewriter 5030 tpcc queries.sql --db-host 127.0.0.1 --db-user myname --schema public

queries.sql为需要改写的SQL,内容如下:

select cfg_name from bmsql_config group by cfg_name having cfg_name='1';
delete from bmsql_config;
delete from bmsql_config where cfg_name='1';

结果为多个改写后的查询语句,显示在屏幕(无法改写的语句,显示为空),如下:

+--------------------------------------------------------------------------+------------------------------+
| Raw SQL                                                                  | Rewritten SQL                |
+--------------------------------------------------------------------------+------------------------------+
| select cfg_name from bmsql_config group by cfg_name having cfg_name='1'; | SELECT cfg_name              |
|                                                                          | FROM bmsql_config            |
|                                                                          | WHERE cfg_name = '1';        |
| delete from bmsql_config;                                                | TRUNCATE TABLE bmsql_config; |
| delete from bmsql_config where cfg_name='1';                             |                              |
+--------------------------------------------------------------------------+------------------------------+

300.3 获取帮助

使用SQL Rewriter前,您可以通过以下指令获取帮助。

gs_dbmind component sql_rewriter --help

显示如下帮助信息:

usage:  [-h] [--db-host DB_HOST] [--db-user DB_USER] [--schema SCHEMA]
        db_port database file
​
SQL Rewriter
​
positional arguments:
  db_port            Port for database
  database           Name for database
  file               File containing SQL statements which need to rewrite
​
optional arguments:
  -h, --help         show this help message and exit
  --db-host DB_HOST  Host for database
  --db-user DB_USER  Username for database log-in
  --schema SCHEMA    Schema name for the current business data

密码通过管道输入或交互式输入,对于免密用户,任意输入都可通过检验。

300.4 命令参考

表 1 命令行参数说明

参数名称释义
db_port数据库端口号
database数据库名称
file包含多个查询语句的文件路径
db-host(可选)数据库主机号
db-user(可选)数据库用户名
schema(可选,模式为public)模式

300.5 常见问题处理

  • SQL无法改写:请查看SQL是否符合改写规则或SQL语法是否正确。

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

image-20240225210139838