什么是QueryMapping

KingbaseES Query Mapping 是一种查询映射功能。有过SQL优化经历的人都知道,对于有些SQL性能问题,可能需要涉及到SQL层面的修改,这不仅麻烦,而且在已上线的系统还存在很大的风险。KingbaseES V8R6 提供了query mapping功能,用户可以通过SQL映射,可以避免直接修改SQL的过程。

QueryMapping的作用

一个无法使用索引的查询语句,通过QueryMapping,可以解决性能问题。

假设应用有这么一条SQL : select id from v_t1 where upper(name)=$1; 可以看下执行计划:由于做了upper转换,无法使用索引。

kingbase=# explain analyze select id from t1 where upper(name)='A1234567';
QUERY PLAN
------------------------------------------------------------------------------------------------------
Seq Scan on t1 (cost=0.00..20435.00 rows=5000 width=4) (actual time=44.860..190.009 rows=1 loops=1)
Filter: (upper(name) = 'A1234567'::text)
Rows Removed by Filter: 999999
Planning Time: 0.113 ms
Execution Time: 190.025 ms
(5 行记录)

KingbaseES Query Mapping 实现不修改SQL,并且能快速解决问题。

set enable_query_rule = on
--创建SQL映射关系
select create_query_rule('qm1','select id from t1 where upper(name)=$1;','select id from t1 where name=lower($1);', true, 'text'); explain (usingquerymapping,analyze) select id from t1 where upper(name)='A1234567';
QUERY PLAN
----------------------------------------------------------------------------------------------------------------
Index Scan using ind_t1_name on t1 (cost=0.42..8.44 rows=1 width=4) (actual time=0.024..0.025 rows=1 loops=1)
Index Cond: (name = 'a1234567'::text)
Planning Time: 0.089 ms
Execution Time: 0.040 ms
(4 行记录)

延伸思考

KingbaseES Query Mapping用一个性能良好的SQL语句,替换原SQL语句,实现性能的提升。如果SQL语句的执行性能良好,但解析性能较慢,是否可以解决SQL语句仅能在事务中实现软解析。

实验场景

一个复杂查询

一个语句复杂的视图,虽然执行性能优良,但解析需要较长的时间,造成查询语句的整体运行时间较长。


kingbase=# explain analyze select id from sch01.v_tun1k where id = 8888;
QUERY PLAN
---------------------------------------------------------------------------------------------------------------------------------
Append (cost=0.28..8293.50 rows=1000 width=4) (actual time=0.088..4.602 rows=1 loops=1)
...
Planning Time: 376.659 ms
Execution Time: 6.621 ms

每次查询返回结果的时间,如下。


kingbase=# select id from sch01.v_tun1k where id = 888; \watch
id
-----
888
(1 行记录) 时间:374.361 ms
2022年09月25日 星期日 15时23分37秒 (每 2s) id
-----
888
(1 行记录) 时间:377.814 ms
2022年09月25日 星期日 15时23分39秒 (每 2s) id
-----
888
(1 行记录) 时间:381.633 ms
2022年09月25日 星期日 15时23分41秒 (每 2s) id
-----
888
(1 行记录) 时间:382.636 ms
2022年09月25日 星期日 15时23分44秒 (每 2s) id
-----
888
(1 行记录) 时间:378.316 ms

函数实现软解析

使用函数可以在同一会话中,执行6次后,实现软解析。


create or replace function f_tun1k(int)
returns table(id int)
language plsql
as
$$
begin
return query select id from sch01.v_tun1k where id = $1;
end;
$$
;

kingbase=# select *,round(date_part('sec',clock_timestamp()-now())*1000,3)||'ms' ms from f_tun1k(8888) ;\watch
id | ms
------+-----------
8888 | 456.109ms
(1 行记录) 2022年09月25日 星期日 15时12分00秒 (每 2s) id | ms
------+-----------
8888 | 382.978ms
(1 行记录) 2022年09月25日 星期日 15时12分02秒 (每 2s) id | ms
------+-----------
8888 | 391.402ms
(1 行记录) 2022年09月25日 星期日 15时12分05秒 (每 2s) id | ms
------+-----------
8888 | 380.328ms
(1 行记录) 2022年09月25日 星期日 15时12分07秒 (每 2s) id | ms
------+-----------
8888 | 385.995ms
(1 行记录) 2022年09月25日 星期日 15时12分09秒 (每 2s) id | ms
------+-----------
8888 | 382.862ms
(1 行记录) 2022年09月25日 星期日 15时12分12秒 (每 2s) id | ms
------+---------
8888 | 9.208ms
(1 行记录) 2022年09月25日 星期日 15时12分14秒 (每 2s) id | ms
------+---------
8888 | 7.971ms
(1 行记录) 2022年09月25日 星期日 15时12分16秒 (每 2s) id | ms
------+---------
8888 | 8.243ms
(1 行记录)

将函数与QueryMapping结合

创建SQL映射关系


kingbase=# select create_query_rule('qm10', 'select id from sch01.v_tun1k where id = $1;', 'select id from f_tun1k($1) ;', true, 'text');
create_query_rule
------------------- (1 行记录)

函数与QueryMapping结合的效果,在同一会话中,原SQL实现了软解析。


kingbase=# select id from sch01.v_tun1k where id = 888; \watch
id
-----
888
(1 行记录) 时间:10.250 ms
2022年09月25日 星期日 15时21分34秒 (每 2s) id
-----
888
(1 行记录) 时间:7.958 ms
2022年09月25日 星期日 15时21分36秒 (每 2s) id
-----
888
(1 行记录) 时间:9.958 ms
2022年09月25日 星期日 15时21分38秒 (每 2s) id
-----
888
(1 行记录) 时间:10.581 ms
2022年09月25日 星期日 15时21分40秒 (每 2s) id
-----
888
(1 行记录) 时间:11.401 ms

在语句块中实现软解析

创建SQL映射关系,在语句块中实现QueryMapping,需要semantics键值。

kingbase=# select create_query_rule('qm11', 'select id from sch01.v_tun1k where id = $1;', 'select id from f_tun1k($1) ;', true, 'semantics');
create_query_rule
------------------- (1 行记录)

在一个会话中,语句块使用组合的软解析效果。


kingbase=# do
kingbase-# $$
kingbase$# declare
kingbase$# v_id int ;
kingbase$# v_ref int;
kingbase$# begin
kingbase$# v_id := (random() * 1000000)::int;
kingbase$# select id into v_ref from sch01.v_tun1k where id = v_id;
kingbase$# raise notice ' ID = % , % ',v_ref , round(date_part('sec', clock_timestamp() - now()) * 1000,3) || 'ms';
kingbase$# end;
kingbase$# $$ \watch
注意: ID = 387169 , 8.635ms
2022年09月25日 星期日 15时33分01秒 (每 2s) ANONYMOUS BLOCK 注意: ID = 35458 , 10.489ms
2022年09月25日 星期日 15时33分03秒 (每 2s) ANONYMOUS BLOCK 注意: ID = 39627 , 9.775ms
2022年09月25日 星期日 15时33分05秒 (每 2s) ANONYMOUS BLOCK 注意: ID = 730817 , 10.634ms
2022年09月25日 星期日 15时33分07秒 (每 2s) ANONYMOUS BLOCK 注意: ID = 582763 , 9.363ms
2022年09月25日 星期日 15时33分09秒 (每 2s) ANONYMOUS BLOCK 注意: ID = 148173 , 9.186ms
2022年09月25日 星期日 15时33分11秒 (每 2s) ANONYMOUS BLOCK 注意: ID = 800521 , 9.766ms
2022年09月25日 星期日 15时33分13秒 (每 2s) ANONYMOUS BLOCK

总结

目前,QueryMapping功能需要手动创建查询脚本的对照关系,不便于大规模的应用,对于频繁且无法优化的查询,也可以提升执行性能。

KingabseES例程之巧用QueryMapping解决查询硬解析问题的更多相关文章

  1. memcache锁,解决查询过多email查询为空的问题

    /* 设置memcache锁,解决查询过多email查询为空的问题 Begin */ $mmc = new Memcache; $mmc->connect('127.0.0.1', 11211) ...

  2. dataGridView1.DataSource,解决查询结果不从第一行显示,而是不断往表下面扩展问题

    private void 洱海各月出流流量frm_Load(object sender, EventArgs e) { //在查询按钮中用下面这段代码会出现打开数据库出错的现象 MyTable1.Ro ...

  3. 解决域名DNS解析的故障

    在实际应用过程中可能会遇到DNS解析错误的问题,就是说当我们访问一个域名时无法完成将其解析到IP地址的工作,而直接输入网站IP却可以正常访问,这就是因为DNS解析出现故障造成的.这个现象发生的机率比较 ...

  4. 使用dig查询dns解析

    原文地址:使用dig查询dns解析 作者:chenwenming 一般来说linux下查询域名解析有两种选择,nslookup或者dig,而在使用上我觉得dig更加方便顺手. 如果是在debian下的 ...

  5. Node基础:url查询参数解析之querystring

    模块概述 在nodejs中,提供了querystring这个模块,用来做url查询参数的解析,使用非常简单. 模块总共有四个方法,绝大部分时,我们只会用到 .parse(). .stringify() ...

  6. 将查询字符串解析转换为泛型List的名值集合.

    ///<summary> ///将查询字符串解析转换为泛型List的名值集合. ///</summary> ///<param name="queryStrin ...

  7. 解决JSP 不解析EL表达式

    解决JSP 不解析EL表达式,jsp在使用EL表达式的时候发现它不被解析,而是直接以字符串的形式显示了出来,经过查阅资料和实践,终于得知了原因并找到了解决方案 原因是:在默认情况下,Servlet 2 ...

  8. IOS CoreData 多表查询demo解析

    在IOS CoreData中,多表查询上相对来说,没有SQL直观,但CoreData的功能还是可以完成相关操作的. 下面使用CoreData进行关系数据库的表与表之间的关系演示.生成CoreData和 ...

  9. 关于ORACLE的硬解析和软解析与MySQL的查询缓存query_cache探讨

    今天在项目中探讨到Oracle对于SQL语句的解析方法以及MySQL相应的处理方法: --------------------------------------------------------- ...

  10. Oracle 硬解析查询

    -- 硬解析的 parse count (hard) select * from v$sysstat where name like '%parse%'; select a.value,b.name ...

随机推荐

  1. React闭包陷阱

    React闭包陷阱 React Hooks是React 16.8引入的一个新特性,其出现让React的函数组件也能够拥有状态和生命周期方法,其优势在于可以让我们在不编写类组件的情况下,更细粒度地复用状 ...

  2. Js中的堆栈

    Js中的堆栈 堆heap是动态分配的内存,大小不定也不会自动释放,栈stack为自动分配的内存空间,在代码执行过程中自动释放. 栈区 在栈内存中提供一个供Js代码执行的环境,关于作用域以及函数的调用都 ...

  3. java generic 介绍

    一 介绍: 在Java SE 1.5之前,没有泛型的情况的下,通过对类型Object的引用来实现参数的"任意化","任意化"带来的缺点是要做显式的强制类型转换, ...

  4. 编译静态库遇到的 LNK2019 报错

    前文提到了 CMake 学习 文末基本涵盖了我遇到的编译问题,但是在得到一个编译好的 .lib 文件后,还需要放到项目中引用成功后才算真正的完成静态库的编译 嗯,我之所以说这些是因为我在项目中链接静态 ...

  5. sort.interface接口

    一个内置的排序算法需要知道三个东西:序列的长度,表示两个元素比较的结果,一种交换两个元素的方式:这就是sort.Interface的三个方法: package sort type Interface ...

  6. 在RecyclerView.Adapter中使用 ViewBinding 的一个注意点

    使用 viewpager2 时遇到如下错误, 使用 recyclerview 也有可能会遇到 : 2022-02-10 14:15:43.510 12151-12151/com.sharpcj.dem ...

  7. Python3中的“联动”现象

    技术背景 在python中定义一个列表时,我们一定要注意其中的可变对象的原理.虽然python的语法中没有指针,但是实际上定义一个列表变量时,是把变量名指到了一个可变对象上.如果此时我们定义另外一个变 ...

  8. 【Azure 事件中心】从Azure Event Hub中消费数据,如何查看当前消费客户端消费数据的Offset和SequenceNumber呢(消息偏移量和序列号)?

    问题描述 当通过Azure Event Hub SDK消费Event Hub中的消息时,必须指定一个Storage Account(存储账号)用于保存 Checkpoint (检查点). 比如在C#代 ...

  9. 详解 nebula 2.0 性能测试和 nebula-importer 数据导入调优

    这是由社区用户--繁凡撰写的一篇他的实践分享,主要讲解如何进行 Nebula 性能测试以及数据导入部分的性能调优.下文中出现的"我"代指用户繁凡. 0. 概要 之前在做 Nebul ...

  10. VC-MFC(1) 随笔笔记+连接数据库

    1 数据库语句: 2 CREATE DATABASE---创建新数据库 3 ALTER DATABASE-----修改数据库 4 CREATE TABLE ---- -创建新表 5 ALTER TAB ...