国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

一次分析的全過程

2024-07-21 02:37:44
字體:
來源:轉載
供稿:網友

  我們的程序員抱怨一段執行很慢的程序,我把代碼執行分析執行計劃,
  后果如下:
  
  這是最初的執行效果及執行計劃
  
  SQL> SELECT "SP_TRANS"."TRANS_NO",
  2 "SP_TRANS_SUB"."ITEM_CODE",
  3 "SP_ITEM"."ITEM_NAME",
  4 "SP_ITEM"."CHART_ID",
  5 "SP_ITEM"."SPECIFICATION",
  6 "SP_TRANS_SUB"."COUNTRY",
  7 "SP_TRANS_SUB"."QTY",
  8 "SP_TRANS_SUB"."PRICE",
  9 "SP_TRANS"."VENDOR_CODE",
  10 "SP_TRANS"."PAY_MODE",
  11 NVL("SP_TRANS_SUB"."PAY_QTY",0),
  12 0 as PAY_THIS
  13 FROM "SP_ITEM",
  14 "SP_TRANS_SUB",
  15 "SP_TRANS"
  16 WHERE ( "SP_TRANS_SUB"."TRANS_NO" = "SP_TRANS"."TRANS_NO" ) and
  17 ( "SP_ITEM"."ITEM_CODE" = "SP_TRANS_SUB"."ITEM_CODE" ) and
  18 ( ( "SP_TRANS"."VENDOR_CODE" = '20011021023') )
  19 /
  
  8 rows selected.
  
  Elapsed: 00: 00: 00.51
  
  Execution Plan
  ----------------------------------------------------------
  0 SELECT STATEMENT Optimizer=CHOOSE
  1 0 NESTED LOOPS
  2 1 NESTED LOOPS
  3 2 TABLE access (FULL) OF 'SP_TRANS'
  4 2 TABLE ACCESS (BY INDEX ROWID) OF 'SP_TRANS_SUB'
  5 4 INDEX (RANGE SCAN) OF 'PK_SP_TRANS_SUB' (UNIQUE)
  6 1 TABLE ACCESS (BY INDEX ROWID) OF 'SP_ITEM'
  7 6 INDEX (UNIQUE SCAN) OF 'PK_SP_ITEM' (UNIQUE)
  
  Statistics
  ----------------------------------------------------------
  0 recursive calls
  4 db block gets
  323 consistent gets
  0 physical reads
  0 redo size
  1809 bytes sent via SQL*Net to client
  425 bytes received via SQL*Net from client
  2 SQL*Net roundtrips to/from client
  0 sorts (memory)
  0 sorts (disk)
  8 rows processed
  此前這幾個表都沒有分析過。
  
  然后我analyze相關表
  SQL> analyze table sp_trans_sub compute statistics;
  
  Table analyzed.
  
  Elapsed: 00: 00: 30.64
  SQL> SELECT "SP_TRANS"."TRANS_NO",
  2 "SP_TRANS_SUB"."ITEM_CODE",
  3 "SP_ITEM"."ITEM_NAME",
  4 "SP_ITEM"."CHART_ID",
  5 "SP_ITEM"."SPECIFICATION",
  6 "SP_TRANS_SUB"."COUNTRY",
  7 "SP_TRANS_SUB"."QTY",
  8 "SP_TRANS_SUB"."PRICE",
  9 "SP_TRANS"."VENDOR_CODE",
  10 "SP_TRANS"."PAY_MODE",
  11 NVL("SP_TRANS_SUB"."PAY_QTY",0),
  12 0 as PAY_THIS
  13 FROM "SP_ITEM",
  14 "SP_TRANS_SUB",
  15 "SP_TRANS"
  16 WHERE ( "SP_TRANS_SUB"."TRANS_NO" = "SP_TRANS"."TRANS_NO" ) and
  17 ( "SP_ITEM"."ITEM_CODE" = "SP_TRANS_SUB"."ITEM_CODE" ) and
  18 ( ( "SP_TRANS"."VENDOR_CODE" = '20011021023') )
  19 /
  
  8 rows selected.
  
  Elapsed: 00: 00: 06.49
  
  Execution Plan
  ----------------------------------------------------------
  0 SELECT STATEMENT Optimizer=CHOOSE (Cost=18577 Card=126726520
  Bytes=30034185240)
  
  1 0 MERGE JOIN (Cost=18577 Card=126726520 Bytes=30034185240)
  2 1 SORT (JOIN) (Cost=14722 Card=310300 Bytes=20790100)
  3 2 HASH JOIN (Cost=358 Card=310300 Bytes=20790100)
  4 3 TABLE ACCESS (FULL) OF 'SP_TRANS' (Cost=43 Card=229
  Bytes=8473)
  
  5 3 TABLE ACCESS (FULL) OF 'SP_TRANS_SUB' (Cost=158 Card
  =135502 Bytes=4065060)
  
  6 1 SORT (JOIN) (Cost=3855 Card=40840 Bytes=6942800)
  7 6 TABLE ACCESS (FULL) OF 'SP_ITEM' (Cost=77 Card=40840 B
  ytes=6942800)
  
  Statistics
  ----------------------------------------------------------
  150 recursive calls
  89 db block gets
  1837 consistent gets
  755 physical reads
  60 redo size
  1732 bytes sent via SQL*Net to client
  425 bytes received via SQL*Net from client
  2 SQL*Net roundtrips to/from client
  4 sorts (memory)
  1 sorts (disk)
  8 rows processed
  
  SQL>
  
  SQL> analyze table sp_trans compute statistics;

  
  Table analyzed.
  
  Elapsed: 00: 00: 13.00
  SQL>
  SQL> SELECT "SP_TRANS"."TRANS_NO",
  2 "SP_TRANS_SUB"."ITEM_CODE",
  3 "SP_ITEM"."ITEM_NAME",
  4 "SP_ITEM"."CHART_ID",
  5 "SP_ITEM"."SPECIFICATION",
  6 "SP_TRANS_SUB"."COUNTRY",
  7 "SP_TRANS_SUB"."QTY",
  8 "SP_TRANS_SUB"."PRICE",
  9 "SP_TRANS"."VENDOR_CODE",
  10 "SP_TRANS"."PAY_MODE",
  11 NVL("SP_TRANS_SUB"."PAY_QTY",0),
  12 0 as PAY_THIS
  13 FROM "SP_ITEM",
  14 "SP_TRANS_SUB",
  15 "SP_TRANS"
  16 WHERE ( "SP_TRANS_SUB"."TRANS_NO" = "SP_TRANS"."TRANS_NO" ) and
  17 ( "SP_ITEM"."ITEM_CODE" = "SP_TRANS_SUB"."ITEM_CODE" ) and
  18 ( ( "SP_TRANS"."VENDOR_CODE" = '20011021023') )
  19 /
  
  8 rows selected.
  
  Elapsed: 00: 00: 01.62
  
  Execution Plan
  ----------------------------------------------------------
  0 SELECT STATEMENT Optimizer=CHOOSE (Cost=1453 Card=447198 Byt
  es=101066748)
  
  1 0 NESTED LOOPS (Cost=1453 Card=447198 Bytes=101066748)
  2 1 HASH JOIN (Cost=358 Card=1095 Bytes=61320)
  3 2 TABLE ACCESS (FULL) OF 'SP_TRANS' (Cost=43 Card=273 By
  tes=7098)
  
  4 2 TABLE ACCESS (FULL) OF 'SP_TRANS_SUB' (Cost=158 Card=1
  35502 Bytes=4065060)
  
  5 1 TABLE ACCESS (BY INDEX ROWID) OF 'SP_ITEM' (Cost=1 Card=
  40840 Bytes=6942800)
  
  6 5 INDEX (UNIQUE SCAN) OF 'PK_SP_ITEM' (UNIQUE)
  
  Statistics
  ----------------------------------------------------------
  0 recursive calls
  8 db block gets
  1344 consistent gets
  0 physical reads
  0 redo size
  1824 bytes sent via SQL*Net to client
  425 bytes received via SQL*Net from client
  2 SQL*Net roundtrips to/from client
  3 sorts (memory)
  0 sorts (disk)
  8 rows processed
  
  SQL>
  SQL> analyze table sp_item compute statistics
  2 /
  
  Table analyzed.
  
  Elapsed: 00: 00: 11.67
  SQL> SELECT "SP_TRANS"."TRANS_NO",
  2 "SP_TRANS_SUB"."ITEM_CODE",
  3 "SP_ITEM"."ITEM_NAME",
  4 "SP_ITEM"."CHART_ID",
  5 "SP_ITEM"."SPECIFICATION",
  6 "SP_TRANS_SUB"."COUNTRY",
  7 "SP_TRANS_SUB"."QTY",
  8 "SP_TRANS_SUB"."PRICE",
  9 "SP_TRANS"."VENDOR_CODE",
  10 "SP_TRANS"."PAY_MODE",
  11 NVL("SP_TRANS_SUB"."PAY_QTY",0),
  12 0 as PAY_THIS
  13 FROM "SP_ITEM",
  14 "SP_TRANS_SUB",
  15 "SP_TRANS"
  16 WHERE ( "SP_TRANS_SUB"."TRANS_NO" = "SP_TRANS"."TRANS_NO" ) and
  17 ( "SP_ITEM"."ITEM_CODE" = "SP_TRANS_SUB"."ITEM_CODE" ) and
  18 ( ( "SP_TRANS"."VENDOR_CODE" = '20011021023') )
  19 /
  
  8 rows selected.
  
  Elapsed: 00: 00: 01.43
  
  Execution Plan
  ----------------------------------------------------------
  0 SELECT STATEMENT Optimizer=CHOOSE (Cost=687 Card=1362 Bytes=
  128028)
  
  1 0 HASH JOIN (Cost=687 Card=1362 Bytes=128028)
  2 1 HASH JOIN (Cost=358 Card=1362 Bytes=76272)
  3 2 TABLE ACCESS (FULL) OF 'SP_TRANS' (Cost=43 Card=273 By
  tes=7098)
  
  4 2 TABLE ACCESS (FULL) OF 'SP_TRANS_SUB' (Cost=158 Card=1
  35502 Bytes=4065060)
  
  5 1 TABLE ACCESS (FULL) OF 'SP_ITEM' (Cost=77 Card=29547 Byt
  es=1122786)
  
  Statistics
  ----------------------------------------------------------
  0 recursive calls
  12 db block gets
  1820 consistent gets
  0 physical reads
  0 redo size
  1732 bytes sent via SQL*Net to client
  425 bytes received via SQL*Net from client
  2 SQL*Net roundtrips to/from client
  3 sorts (memory) right">(出處:清風軟件下載學院)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南通市| 利川市| 萨嘎县| 腾冲县| 湘乡市| 普格县| 阜阳市| 改则县| 饶平县| 广安市| 图木舒克市| 抚顺县| 含山县| 祁门县| 介休市| 南充市| 万盛区| 临漳县| 改则县| 顺义区| 房产| 鄂托克前旗| 彰化县| 济南市| 昔阳县| 岢岚县| 德兴市| 吴江市| 东丰县| 吴川市| 普安县| 扶绥县| 芷江| 永顺县| 明水县| 东乌| 三明市| 社旗县| 海南省| 威海市| 社旗县|