侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Oracle 12CR2查询转换教程之表扩展详解

数据库  /  管理员 发布于 6年前   186

前言

在表扩展中,对于读取一个分区表部分数据时优化器会生成使用索引的执行计划。基于索引执行计划可以提高性能,但索引维护会增加开锁。在许多数据库中,DML只影响小部分数据。对于频繁更新的表表扩展使用基于索引的执行计划。你可以在以读取为主的数据上创建一个索引,在以频繁变化的数据上消除索引开销。通过这种方式,表扩展在避免索引维护的同时提高了性能。

下面话不多说了,来一起看看详细的介绍吧

表扩展工作原理

表分区使用表扩展成为可能。如果在一个分区表上创建一个本地索引,那么优化器可能会标记索引对于特定的分区不可使用。实际有些分区没有创建索引。在表扩展中,优化器将查询转换为一个union all语句,让一些子查询访问创建索引的分区,一些子查询访问没有创建索引的分区。优化器可以为每个分区选择最有效的访问路径,而不管它是否存在于查询所要访问的所有分区中。

优化器不总是会选择表扩展

.表扩展是基于成本

当数据库访问扩展表的每个分区只会跨越union all的所有分支一次,数据库所连接的任何表都是在分支中被访问。

.语义问题可能导致表扩展无效

例如,一个表出现在一个外连接的右边对于表扩展来说是无效的。

可以使用expand_table hint来控制表扩展。这个hint会覆盖基于成本的决策,但不会覆盖语义检查。

表扩展使用场景

优化器基于查询中出现的谓词条件对每个表必须被访问的分区保持跟踪。分区裁剪能让优化器使用表扩展来生成更有效的执行计划。

下面的例子假设满足以下条件:

.想要对sh.sales表执行星型查询,表sh.sales是基于time_id列进行范围分区的一个分区表。

.想要禁用特定分区上的索引来查看表扩展的优点。

操作步骤如下:

1.以sh用户登录数据库

[oracle@jytest1 ~]$ sqlplus sh/*****@jypdbSQL*Plus: Release 12.2.0.1.0 Production on Wed Oct 31 18:09:54 2018Copyright (c) 1982, 2016, Oracle. All rights reserved.Last Successful login time: Wed Oct 24 2018 17:00:11 +08:00Connected to:Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit ProductionSQL> 

2.执行以下查询

SQL> select * from sales where time_id >= to_date('2000-01-01 00:00:00', 'syyyy-mm-dd hh24:mi:ss') and prod_id = 38;........... 38 2470 24-DEC-01  2 999  1 31.47 38 13440 24-DEC-01  2 999  1 31.47 38 490 28-DEC-01  2 999  1 31.47 38 8406 28-DEC-01  2 999  1 31.47 38 1466 31-DEC-01  3 351  1 31.47 38 4340 31-DEC-01  3 351  1 31.47 38 10658 31-DEC-01  3 351  1 31.47 38 11390 31-DEC-01  3 351  1 31.47 38 23226 31-DEC-01  3 351  1 31.474224 rows selected.

3.查询执行计划

SQL> select * from table(dbms_xplan.display_cursor(null,null,'advanced allstats last runstats_last peeked_binds'));SQL_ID 214qgysqqz0k8, child number 0-------------------------------------select * from sales where time_id >= to_date('2000-01-01 00:00:00','syyyy-mm-dd hh24:mi:ss') and prod_id = 38Plan hash value: 2342444420-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| Id | Operation     | Name  | Starts | E-Rows |E-Bytes| Cost (%CPU)| E-Time | Pstart| Pstop | A-Rows | A-Time | Buffers |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| 0 | SELECT STATEMENT    |  | 1 | | | 224 (100)|  | | | 4224 |00:00:00.03 | 334 || 1 | PARTITION RANGE ITERATOR   |  | 1 | 5078 | 143K| 224 (0)| 00:00:01 | 13 | 28 | 4224 |00:00:00.03 | 334 || 2 | TABLE ACCESS BY LOCAL INDEX ROWID BATCHED| SALES  | 16 | 5078 | 143K| 224 (0)| 00:00:01 | 13 | 28 | 4224 |00:00:00.02 | 334 || 3 | BITMAP CONVERSION TO ROWIDS  |  | 8 | | |  |  | | | 4224 |00:00:00.01 | 24 ||* 4 | BITMAP INDEX SINGLE VALUE  | SALES_PROD_BIX | 8 | | |  |  | 13 | 28 | 8 |00:00:00.01 | 24 |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------Query Block Name / Object Alias (identified by operation id):------------------------------------------------------------- 1 - SEL$1 2 - SEL$1 / SALES@SEL$1Outline Data------------- /*+ BEGIN_OUTLINE_DATA IGNORE_OPTIM_EMBEDDED_HINTS OPTIMIZER_FEATURES_ENABLE('12.2.0.1') DB_VERSION('12.2.0.1') ALL_ROWS NO_PARALLEL OUTLINE_LEAF(@"SEL$1") BITMAP_TREE(@"SEL$1" "SALES"@"SEL$1" AND(("SALES"."PROD_ID"))) BATCH_TABLE_ACCESS_BY_ROWID(@"SEL$1" "SALES"@"SEL$1") END_OUTLINE_DATA */Predicate Information (identified by operation id):--------------------------------------------------- 4 - access("PROD_ID"=38)Column Projection Information (identified by operation id):----------------------------------------------------------- 1 - "PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22], "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 2 - "PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22], "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 3 - "SALES".ROWID[ROWID,10], "PROD_ID"[NUMBER,22] 4 - STRDEF[BM VAR, 10], STRDEF[BM VAR, 10], STRDEF[BM VAR, 7920], "PROD_ID"[NUMBER,22]Note----- - automatic DOP: Computed Degree of Parallelism is 1 because of parallel threshold58 rows selected.

在执行计划中的Pstart与Pstop列,显示了优化器判断只需要访问表的13到28分区。在优化器已经判断了被访问的分区之后,它将考虑所有这些分区上可以使用的索引。在上面的执行计划中,优化器选择使用sales_prod_bix位图索引

4.禁用sales表中sales_1995分区上的索引;

SQL> alter index sales_prod_bix modify partition sales_1995 unusable;Index altered.

5.再次执行之前的查询语句,然后显示执行计划,可以看到执行计划变成了由两个子查询组成的union all语句,第一个子查询还是对13-28分区使用索引,第二个子查询步骤对应的Pstart与Pstop为invalid,id=11的过滤条件为”PROD_ID”=38,id=9的过滤条件为”SALES”.”TIME_ID”=TO_DATE(‘ 2000-01-01 00:00:00', ‘syyyy-mm-dd hh24:mi:ss')))这个过滤条件是为否的,所以过滤后的记录为0,从对应的A-Rows列也可以看到记录为0

SQL> select * from table(dbms_xplan.display_cursor(null,null,'advanced allstats last runstats_last peeked_binds'));SQL_ID 214qgysqqz0k8, child number 0-------------------------------------select * from sales where time_id >= to_date('2000-01-01 00:00:00','syyyy-mm-dd hh24:mi:ss') and prod_id = 38Plan hash value: 238952339--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| Id | Operation          | Name   | Starts | E-Rows |E-Bytes| Cost (%CPU)| E-Time | Pstart| Pstop | A-Rows | A-Time | Buffers |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| 0 | SELECT STATEMENT        |    |  1 |  |  | 224 (100)|   |  |  | 4224 |00:00:00.05 |  334 || 1 | VIEW           | VW_TE_2  |  1 | 5079 | 431K| 224 (0)| 00:00:01 |  |  | 4224 |00:00:00.05 |  334 || 2 | UNION-ALL         |    |  1 |  |  |   |   |  |  | 4224 |00:00:00.05 |  334 || 3 | PARTITION RANGE ITERATOR     |    |  1 | 5078 | 143K| 224 (0)| 00:00:01 | 13 | 28 | 4224 |00:00:00.03 |  334 || 4 |  TABLE ACCESS BY LOCAL INDEX ROWID BATCHED | SALES   |  16 | 5078 | 143K| 224 (0)| 00:00:01 | 13 | 28 | 4224 |00:00:00.02 |  334 || 5 |  BITMAP CONVERSION TO ROWIDS    |    |  8 |  |  |   |   |  |  | 4224 |00:00:00.01 |  24 ||* 6 |  BITMAP INDEX SINGLE VALUE    | SALES_PROD_BIX |  8 |  |  |   |   | 13 | 28 |  8 |00:00:00.01 |  24 ||* 7 | FILTER          |    |  1 |  |  |   |   |  |  |  0 |00:00:00.01 |  0 || 8 |  PARTITION RANGE EMPTY      |    |  0 |  1 | 29 |  1 (0)| 00:00:01 |INVALID|INVALID|  0 |00:00:00.01 |  0 ||* 9 |  TABLE ACCESS BY LOCAL INDEX ROWID BATCHED| SALES   |  0 |  1 | 29 |  1 (0)| 00:00:01 |INVALID|INVALID|  0 |00:00:00.01 |  0 || 10 |  BITMAP CONVERSION TO ROWIDS    |    |  0 |  |  |   |   |  |  |  0 |00:00:00.01 |  0 ||* 11 |  BITMAP INDEX SINGLE VALUE    | SALES_PROD_BIX |  0 |  |  |   |   |INVALID|INVALID|  0 |00:00:00.01 |  0 |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------Query Block Name / Object Alias (identified by operation id):------------------------------------------------------------- 1 - SET$D0A14387 / VW_TE_2@SEL$0A5B0FFE 2 - SET$D0A14387 3 - SET$D0A14387_1 4 - SET$D0A14387_1 / SALES@SEL$1 7 - SET$D0A14387_2 9 - SET$D0A14387_2 / SALES@SEL$1Outline Data------------- /*+  BEGIN_OUTLINE_DATA  IGNORE_OPTIM_EMBEDDED_HINTS  OPTIMIZER_FEATURES_ENABLE('12.2.0.1')  DB_VERSION('12.2.0.1')  ALL_ROWS  NO_PARALLEL  OUTLINE_LEAF(@"SET$D0A14387_2")  OUTLINE_LEAF(@"SET$D0A14387_1")  OUTLINE_LEAF(@"SET$D0A14387")  EXPAND_TABLE(@"SEL$1" "SALES"@"SEL$1")  OUTLINE_LEAF(@"SEL$0A5B0FFE")  OUTLINE(@"SET$D0A14387")  EXPAND_TABLE(@"SEL$1" "SALES"@"SEL$1")  OUTLINE(@"SEL$1")  NO_ACCESS(@"SEL$0A5B0FFE" "VW_TE_2"@"SEL$0A5B0FFE")  BITMAP_TREE(@"SET$D0A14387_1" "SALES"@"SEL$1" AND(("SALES"."PROD_ID")))  BATCH_TABLE_ACCESS_BY_ROWID(@"SET$D0A14387_1" "SALES"@"SEL$1")  BITMAP_TREE(@"SET$D0A14387_2" "SALES"@"SEL$1" AND(("SALES"."PROD_ID")))  BATCH_TABLE_ACCESS_BY_ROWID(@"SET$D0A14387_2" "SALES"@"SEL$1")  END_OUTLINE_DATA */Predicate Information (identified by operation id):--------------------------------------------------- 6 - access("PROD_ID"=38) 7 - filter(NULL IS NOT NULL) 9 - filter(("SALES"."TIME_ID"=TO_DATE(' 2000-01-01 00:00:00', 'syyyy-mm-dd    hh24:mi:ss'))) 11 - access("PROD_ID"=38)Column Projection Information (identified by operation id):----------------------------------------------------------- 1 - "ITEM_1"[NUMBER,22], "ITEM_2"[NUMBER,22], "ITEM_3"[DATE,7], "ITEM_4"[NUMBER,22], "ITEM_5"[NUMBER,22], "ITEM_6"[NUMBER,22], "ITEM_7"[NUMBER,22] 2 - STRDEF[22], STRDEF[22], STRDEF[7], STRDEF[22], STRDEF[22], STRDEF[22], STRDEF[22] 3 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 4 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 5 - "SALES".ROWID[ROWID,10], "SALES"."PROD_ID"[NUMBER,22] 6 - STRDEF[BM VAR, 10], STRDEF[BM VAR, 10], STRDEF[BM VAR, 7920], "SALES"."PROD_ID"[NUMBER,22] 7 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 8 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 9 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 10 - "SALES".ROWID[ROWID,10], "SALES"."PROD_ID"[NUMBER,22] 11 - STRDEF[BM VAR, 10], STRDEF[BM VAR, 10], STRDEF[BM VAR, 7920], "SALES"."PROD_ID"[NUMBER,22]Note----- - automatic DOP: Computed Degree of Parallelism is 1 because of parallel threshold93 rows selected.

6.禁用分区28上的索引(sales_q4_2003),它是查询需要访问的一个分区:

SQL> alter index sales_prod_bix modify partition sales_q4_2003 unusable;Index altered.SQL> alter index sales_time_bix modify partition sales_q4_2003 unusable;Index altered.

通过禁用查询需要访问分区上的索引,查询将不能再使用这些索引。

7.再次执行查询语句,其执行计划如下,执行计划变成了由三个子查询组成的union all语句,相比之前查询多的第三个子查询对表sales的第28个分区执行全表扫描,这里没有索引可用,因为已经禁用28分区上的索引了。

SQL> select * from table(dbms_xplan.display_cursor(null,null,'advanced allstats last runstats_last peeked_binds'));SQL_ID 214qgysqqz0k8, child number 0-------------------------------------select * from sales where time_id >= to_date('2000-01-01 00:00:00','syyyy-mm-dd hh24:mi:ss') and prod_id = 38Plan hash value: 3857158179-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| Id | Operation          | Name   | Starts | E-Rows |E-Bytes| Cost (%CPU)| E-Time | Pstart| Pstop | A-Rows | A-Time | Buffers | Reads |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| 0 | SELECT STATEMENT        |    |  1 |  |  | 225 (100)|   |  |  | 4224 |00:00:00.20 |  334 |  44 || 1 | VIEW           | VW_TE_2  |  1 | 5080 | 431K| 225 (0)| 00:00:01 |  |  | 4224 |00:00:00.20 |  334 |  44 || 2 | UNION-ALL         |    |  1 |  |  |   |   |  |  | 4224 |00:00:00.19 |  334 |  44 || 3 | PARTITION RANGE ITERATOR     |    |  1 | 5078 | 143K| 223 (0)| 00:00:01 | 13 | 27 | 4224 |00:00:00.17 |  334 |  44 || 4 |  TABLE ACCESS BY LOCAL INDEX ROWID BATCHED | SALES   |  15 | 5078 | 143K| 223 (0)| 00:00:01 | 13 | 27 | 4224 |00:00:00.16 |  334 |  44 || 5 |  BITMAP CONVERSION TO ROWIDS    |    |  8 |  |  |   |   |  |  | 4224 |00:00:00.03 |  24 |  16 ||* 6 |  BITMAP INDEX SINGLE VALUE    | SALES_PROD_BIX |  8 |  |  |   |   | 13 | 27 |  8 |00:00:00.03 |  24 |  16 ||* 7 | FILTER          |    |  1 |  |  |   |   |  |  |  0 |00:00:00.01 |  0 |  0 || 8 |  PARTITION RANGE EMPTY      |    |  0 |  1 | 29 |  1 (0)| 00:00:01 |INVALID|INVALID|  0 |00:00:00.01 |  0 |  0 ||* 9 |  TABLE ACCESS BY LOCAL INDEX ROWID BATCHED| SALES   |  0 |  1 | 29 |  1 (0)| 00:00:01 |INVALID|INVALID|  0 |00:00:00.01 |  0 |  0 || 10 |  BITMAP CONVERSION TO ROWIDS    |    |  0 |  |  |   |   |  |  |  0 |00:00:00.01 |  0 |  0 ||* 11 |  BITMAP INDEX SINGLE VALUE    | SALES_PROD_BIX |  0 |  |  |   |   |INVALID|INVALID|  0 |00:00:00.01 |  0 |  0 || 12 | PARTITION RANGE SINGLE      |    |  1 |  1 | 87 |  2 (0)| 00:00:01 | 28 | 28 |  0 |00:00:00.01 |  0 |  0 ||* 13 |  TABLE ACCESS FULL       | SALES   |  1 |  1 | 87 |  2 (0)| 00:00:01 | 28 | 28 |  0 |00:00:00.01 |  0 |  0 |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------Query Block Name / Object Alias (identified by operation id):------------------------------------------------------------- 1 - SET$D0A14387 / VW_TE_2@SEL$0A5B0FFE 2 - SET$D0A14387 3 - SET$D0A14387_1 4 - SET$D0A14387_1 / SALES@SEL$1 7 - SET$D0A14387_2 9 - SET$D0A14387_2 / SALES@SEL$1 12 - SET$D0A14387_3 13 - SET$D0A14387_3 / SALES@SEL$1Outline Data------------- /*+  BEGIN_OUTLINE_DATA  IGNORE_OPTIM_EMBEDDED_HINTS  OPTIMIZER_FEATURES_ENABLE('12.2.0.1')  DB_VERSION('12.2.0.1')  ALL_ROWS  NO_PARALLEL  OUTLINE_LEAF(@"SET$D0A14387_3")  OUTLINE_LEAF(@"SET$D0A14387_2")  OUTLINE_LEAF(@"SET$D0A14387_1")  OUTLINE_LEAF(@"SET$D0A14387")  EXPAND_TABLE(@"SEL$1" "SALES"@"SEL$1")  OUTLINE_LEAF(@"SEL$0A5B0FFE")  OUTLINE(@"SET$D0A14387")  EXPAND_TABLE(@"SEL$1" "SALES"@"SEL$1")  OUTLINE(@"SEL$1")  NO_ACCESS(@"SEL$0A5B0FFE" "VW_TE_2"@"SEL$0A5B0FFE")  BITMAP_TREE(@"SET$D0A14387_1" "SALES"@"SEL$1" AND(("SALES"."PROD_ID")))  BATCH_TABLE_ACCESS_BY_ROWID(@"SET$D0A14387_1" "SALES"@"SEL$1")  BITMAP_TREE(@"SET$D0A14387_2" "SALES"@"SEL$1" AND(("SALES"."PROD_ID")))  BATCH_TABLE_ACCESS_BY_ROWID(@"SET$D0A14387_2" "SALES"@"SEL$1")  FULL(@"SET$D0A14387_3" "SALES"@"SEL$1")  END_OUTLINE_DATA */Predicate Information (identified by operation id):--------------------------------------------------- 6 - access("PROD_ID"=38) 7 - filter(NULL IS NOT NULL) 9 - filter(("SALES"."TIME_ID"=TO_DATE(' 2000-01-01 00:00:00', 'syyyy-mm-dd hh24:mi:ss'))) 11 - access("PROD_ID"=38) 13 - filter("PROD_ID"=38)Column Projection Information (identified by operation id):----------------------------------------------------------- 1 - "ITEM_1"[NUMBER,22], "ITEM_2"[NUMBER,22], "ITEM_3"[DATE,7], "ITEM_4"[NUMBER,22], "ITEM_5"[NUMBER,22], "ITEM_6"[NUMBER,22], "ITEM_7"[NUMBER,22] 2 - STRDEF[22], STRDEF[22], STRDEF[7], STRDEF[22], STRDEF[22], STRDEF[22], STRDEF[22] 3 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 4 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 5 - "SALES".ROWID[ROWID,10], "SALES"."PROD_ID"[NUMBER,22] 6 - STRDEF[BM VAR, 10], STRDEF[BM VAR, 10], STRDEF[BM VAR, 7920], "SALES"."PROD_ID"[NUMBER,22] 7 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 8 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 9 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 10 - "SALES".ROWID[ROWID,10], "SALES"."PROD_ID"[NUMBER,22] 11 - STRDEF[BM VAR, 10], STRDEF[BM VAR, 10], STRDEF[BM VAR, 7920], "SALES"."PROD_ID"[NUMBER,22] 12 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22] 13 - "SALES"."PROD_ID"[NUMBER,22], "SALES"."CUST_ID"[NUMBER,22], "SALES"."TIME_ID"[DATE,7], "SALES"."CHANNEL_ID"[NUMBER,22], "SALES"."PROMO_ID"[NUMBER,22],  "SALES"."QUANTITY_SOLD"[NUMBER,22], "SALES"."AMOUNT_SOLD"[NUMBER,22]Note----- - automatic DOP: Computed Degree of Parallelism is 1 because of parallel threshold103 rows selected.

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对AIDI的支持。


  • 上一条:
    Oracle 12CR2查询转换教程之cursor-duration临时表详解
    下一条:
    Oracle固定执行计划之SQL PROFILE概要文件详解
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 分库分表的目的、优缺点及具体实现方式介绍(0个评论)
    • DevDB - 在 VS 代码中直接访问数据库(0个评论)
    • 在ubuntu系统中实现mysql数据存储目录迁移流程步骤(0个评论)
    • 在mysql中使用存储过程批量新增测试数据流程步骤(0个评论)
    • php+mysql数据库批量根据条件快速更新、连表更新sql实现(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-06
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-01
    • 2018-05
    • 2018-10
    • 2018-11
    • 2020-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2021-02
    • 2021-04
    • 2021-07
    • 2021-08
    • 2021-11
    • 2021-12
    • 2022-02
    • 2022-03
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-07
    • 2023-08
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客