TABLE LOOKUP

TABLE LOOKUP 算子用于表示全局索引的回表逻辑。

示例:全局索引回表

obclient>CREATE TABLE t1(c1 INT PRIMARY KEY, c2 INT, c3 INT) PARTITION BY 
       HASH(c1) PARTITIONS 4;
Query OK, 0 rows affected (0.12 sec)

obclient>CREATE INDEX i1 ON t1(c2) GLOBAL;
Query OK, 0 rows affected (0.12 sec)

obclient>EXPLAIN SELECT * FROM t1 WHERE c2 = 1\G;
*************************** 1. row ***************************
Query Plan:
| ========================================
|ID|OPERATOR    |NAME  |EST. ROWS|COST |
----------------------------------------
|0 |TABLE LOOKUP|t1    |3960     |31065|
|1 | TABLE SCAN |t1(i1)|3960     |956  |
========================================

Outputs & filters:
-------------------------------------
  0 - output([t1.c1], [t1.c2], [t1.c3]), filter(nil),
      partitions(p[0-3])
  1 - output([t1.c1]), filter(nil),
      access([t1.c1]), partitions(p0)

上述示例中,1 号算子是扫描全局索引 i1,0 号算子表明从主表中获取不在全局索引的列。执行计划展示中的 outputs & filters 详细展示了 TABLE LOOKUP 算子的输出信息如下:

信息名称

含义

output

该算子的输出列。

filter

该算子的过滤谓词。

由于示例中 TABLE LOOKUP 算子没有设置 filter,所以为 nil

partitions

查询需要扫描的分区。