精品日韩在线,日韩精品福利一区二区三区,日韩午夜黄色,国产日韩欧美高清免费

始創于2000年 股票代碼:831685
咨詢熱線:0371-60135900 注冊有禮 登錄
  • 掛牌上市企業
  • 60秒人工響應
  • 99.99%連通率
  • 7*24h人工
  • 故障100倍補償
您的位置: 網站首頁 > 幫助中心>文章內容

Oracle教程:select 操作產生的 redo

發布時間:  2012/8/26 16:06:44

數據庫版本:
Oracle Database 10g Enterprise Edition Release 10.1.0.3.0


創建測試表:
SQL> create table a  as select * from all_objects  ;
Table created.
-
 


SQL> set autotrace on statistics ;

插入數據(hint append):

SQL> insert /*+ append */ into a select * from all_objects ;
9891 rows created.

Statistics
----------------------------------------------------------
        302  recursive calls
        137  db block gets
       6040  consistent gets
          0  physical reads
    1055332  redo size
        627  bytes sent via SQL*Net to client
        558  bytes received via SQL*Net from client
          3  SQL*Net roundtrips to/from client
          1  sorts (memory)
          0  sorts (disk)
       9891  rows processed
SQL> commit ;
Commit complete.

第一次查詢數據:
SQL> select count(*) from a ;
  COUNT(*)
----------
     19782

Statistics
----------------------------------------------------------
          0  recursive calls
          1  db block gets
        255  consistent gets
        248  physical reads
  168  redo size    ---------------------------------> ???產生redo???
        395  bytes sent via SQL*Net to client
        507  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          1  rows processed


第二次查詢:

SQL> select count(*) from a ;
  COUNT(*)
----------
     19782

Statistics
----------------------------------------------------------
          0  recursive calls
          0  db block gets
        252  consistent gets
          1  physical reads
    0 redo size      
        395  bytes sent via SQL*Net to client
        507  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          1  rows processed


=================================================
如上所示,為什么在查詢的時候會產生 redo ? 產生的redo 到底是做什么的?
=================================================
----

取消 hint append 插入數據,第一次查詢不會產生redo

SQL> insert into a select * from a ;

19782 rows created.


Statistics
----------------------------------------------------------
        112  recursive calls
      21100  db block gets
        699  consistent gets
          0  physical reads
    7149196  redo size
        642  bytes sent via SQL*Net to client
        534  bytes received via SQL*Net from client
          3  SQL*Net roundtrips to/from client
          1  sorts (memory)
          0  sorts (disk)
      19782  rows processed

SQL>
SQL>
SQL> select count(*) from a ;

  COUNT(*)
----------
     39564


Statistics
----------------------------------------------------------
          0  recursive calls
          0  db block gets
        502  consistent gets
          0  physical reads
          0  redo size
        395  bytes sent via SQL*Net to client
        507  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          1  rows processed
---------------------------------------------------

對表做了truncate 操作后,第一次查詢也出現 redo

SQL> truncate table a ;

Table truncated.

SQL>
SQL> select count(*) from a;

  COUNT(*)
----------
         0


Statistics
----------------------------------------------------------
          1  recursive calls
          1  db block gets
          6  consistent gets
          0  physical reads
       96  redo size
        392  bytes sent via SQL*Net to client
        507  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          1  rows processed

SQL>

----------------
簡單的說,在Oracle的block上都有活動事務的標志的,如果一個事務commit后,由于某些block在commit之前已經寫回datafile, 或者事務影響到的block數過多,則commi的時候只會清理undo segment header中的事務表信息,data block上的事務標志不會清除,否則代價過高。那么在一些讀取這些block時,需要將這些事務標志進行清除,就是延遲塊清除
-------------------------
這個在用append引語的時候才會產生select的redo日志,說明在提交前已經把數據塊給寫了,也進一步說明了直插的模式,就是不走緩存,直接寫數據塊和回滾快。滿足延遲塊清除的第一個條件,就是還沒提交,數據已經寫了。
---------------------------
====================================
在做個測試如下:
====================================

SQL> insert into a
  2  select * from a ;

129103 rows created.


Statistics
----------------------------------------------------------
        489  recursive calls
     137442  db block gets
       4058  consistent gets
       1516  physical reads
   46645744  redo size
        643  bytes sent via SQL*Net to client
        534  bytes received via SQL*Net from client
          3  SQL*Net roundtrips to/from client
          1  sorts (memory)
          0  sorts (disk)
     129103  rows processed

SQL> alter system checkpoint ;

System altered.

SQL>
SQL> select count(*) from a ;

  COUNT(*)
----------
    258206


Statistics
----------------------------------------------------------
          0  recursive calls
          0  db block gets
       3241  consistent gets
       2790  physical reads
          0  redo size
        395  bytes sent via SQL*Net to client
        507  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          1  rows processed

SQL> commit ;

Commit complete.

SQL> select count(*) from a ;

  COUNT(*)
----------
    258206


Statistics
----------------------------------------------------------
          0  recursive calls
          0  db block gets
       4857  consistent gets
       2796  physical reads
      116484  redo size ------------------------------------> 第一次查詢redo產生 (延遲塊清除)
        395  bytes sent via SQL*Net to client
        507  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          1  rows processed

SQL> select count(*) from a ;

  COUNT(*)
----------
    258206


Statistics
----------------------------------------------------------
          0  recursive calls
          0  db block gets
       3241  consistent gets
       2746  physical reads
          0  redo size       
       395  bytes sent via SQL*Net to client
        507  bytes received via SQL*Net from client
          2  SQL*Net roundtrips to/from client
          0  sorts (memory)
          0  sorts (disk)
          1  rows processed

SQL>

-------------------
說白了就是數據塊上的信息在前面還沒來得及清理,select來幫它清理一下,既然select對數據塊做了操作了,自然就要寫redo了。
 


本文出自:億恩科技【www.zuiquanben.com】

服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

  • 您可能在找
  • 億恩北京公司:
  • 經營性ICP/ISP證:京B2-20150015
  • 億恩鄭州公司:
  • 經營性ICP/ISP/IDC證:豫B1-20183354
  • 億恩南昌公司:
  • 經營性ICP/ISP證:贛B2-20080012
  • 服務器/云主機 24小時售后服務電話:0371-60135900
  • 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
  • 網絡版權侵權舉報電話:0371-60135995
  • 警情提示:注意防范電信網絡詐騙
  • 專注服務器托管17年
    掃掃關注-微信公眾號
    0371-60135900
    Copyright© 1999-2026 ENKJ All Rights Reserved 地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師  B1-20183354   京公網安備41019702002023號 
      0
     
     
     
     

    0371-60135900
    7*24小時客服服務熱線

     
     
    精品日韩在线,日韩精品福利一区二区三区,日韩午夜黄色,国产日韩欧美高清免费
    奇米狠狠一区二区三区| 久久午夜影院| 国产一区二区三区网| 国产精品一区二区精品视频观看 | 久久亚洲黄色| 成人一区而且| 精品亚洲成人| 欧美aa一级| 欧美日韩国产一区二区三区不卡| 91精品一区二区三区综合在线爱| 午夜视频精品| 少妇精品久久久一区二区| 天海翼亚洲一区二区三区| 国产精品中文字幕制服诱惑| 国产一区二区三区四区五区| 日韩欧美1区| 日韩毛片在线| 免费观看日韩电影| 国产精品视频3p| 国产一区三区在线播放| 高清av不卡| 国产精品美女| 日韩av网站免费在线| 高清av一区| 黄色国产精品| 欧美日韩一区二区三区在线电影| 精品日韩一区| 亚洲少妇自拍| 国产精品v一区二区三区| 日韩大片在线| 男女性色大片免费观看一区二区 | 亚洲精品小说| 日本不卡高清| 婷婷激情一区| 亚洲性视频在线| 久久精品亚洲| 99视频一区| 免费在线观看一区| 99视频在线精品国自产拍免费观看| 国产欧美大片| 不卡视频在线| 欧美日韩国产高清| 日韩三级一区| 亚洲高清二区| 国产日产精品_国产精品毛片 | 日本精品一区二区三区在线观看视频| 欧美视频久久| 欧美亚洲精品在线| 国产精品视频一区二区三区四蜜臂 | 午夜精品影视国产一区在线麻豆| 欧美国产日韩电影| 在线看片不卡| 精品久久网站| 国产精品嫩草99av在线| 精品91福利视频| 只有精品亚洲| 亚洲欧美专区| 都市激情国产精品| 日韩av网站免费在线| 98精品视频| 日韩精品一区二区三区中文字幕| www成人在线视频| 国产精品自拍区| 伊人久久大香线蕉av超碰演员| 国产精品久久久久77777丨| 国产一级久久| 99视频精品全部免费在线视频| 特黄特色欧美大片| 国产欧美视频在线| 亚洲一区二区三区四区电影 | 亚洲精品成人一区| 91精品婷婷色在线观看| 美女久久久久久| 日本伊人午夜精品| 国产精品88久久久久久| 天堂√中文最新版在线| 久久久精品区| 国产精品视频一区二区三区四蜜臂| 日本 国产 欧美色综合| 在线一区欧美| 亚洲欧美一区在线| 久久中文字幕av一区二区不卡| 国产suv精品一区二区四区视频| 欧美日韩一区二区三区在线电影| 人人爽香蕉精品| 91精品99| 亚洲精品网址| 图片区亚洲欧美小说区| 丝袜美腿诱惑一区二区三区| 精品一区视频| 精品少妇av| 粉嫩av一区二区三区四区五区| 欧美日韩一区二区国产| 99亚洲视频| 日韩午夜免费| 国产综合精品| 亚洲福利久久| 欧美日韩视频| 亚洲免费影院| 中文精品在线| 亚洲少妇自拍| 免费在线观看一区二区三区| 亚洲欧美久久久| 在线综合亚洲| 综合色就爱涩涩涩综合婷婷| 亚洲男人在线| 国产日韩免费| 精品五月天堂| 丝袜美腿诱惑一区二区三区| 亚洲a在线视频| 国产视频一区在线观看一区免费| 久久国产99| 只有精品亚洲| 国产乱人伦丫前精品视频| 美日韩一区二区三区| 国产精品极品国产中出| 精品91福利视频| 成人三级高清视频在线看| 91精品久久久久久久久久不卡| 欧美搞黄网站| 亚洲免费毛片| 久久成人av| 日韩成人三级| 国产亚洲综合精品| 深夜日韩欧美| 国产精品国产一区| 免费久久久久久久久| 蜜桃av一区二区| 国产精品主播在线观看| 首页国产精品| japanese国产精品| 亚洲综合中文| 精品国产精品国产偷麻豆 | 精品国产a一区二区三区v免费| zzzwww在线看片免费| 成人精品中文字幕| 亚洲一区二区三区四区电影| 国产极品模特精品一二| 久久视频国产| 日韩中文字幕视频网| 免费亚洲婷婷| 激情五月色综合国产精品| 深夜日韩欧美| 中文字幕在线视频久| 久久99伊人| 久久精品国产999大香线蕉| 精品中文一区| 国产精品欧美大片| 亚洲久草在线| 成人国产精品一区二区网站| 五月天久久久| 国产日韩视频在线| 欧美日韩中文一区二区| 久久国内精品| 欧美国产91| 麻豆91精品91久久久的内涵| 激情偷拍久久| 国产欧美一级| 99在线精品免费视频九九视| 91成人精品观看| 三级精品视频| 国产福利亚洲| 亚洲欧美日韩精品一区二区 | 免费观看日韩电影| 日韩欧美国产精品综合嫩v| 日韩综合一区二区| 国产99精品一区| 美女久久久久久| 欧美综合二区| 国产美女高潮在线观看| 亚洲免费中文| 色天使综合视频| 91欧美日韩在线| 在线日韩一区| 国产视频一区二区在线播放| 一区免费在线| 中文字幕一区久| 国产日韩中文在线中文字幕 | 日本欧美一区二区在线观看| 亚洲精品.com| 国产精品久久国产愉拍| 中文字幕av一区二区三区人 | 日韩精品第一| 91久久国产| 成人在线视频区| 欧美日韩在线精品一区二区三区激情综合 | 免费精品视频| 成年男女免费视频网站不卡| 欧美一级二级视频| 亚洲欧美日韩一区在线观看| 日本久久黄色| 欧美激情综合| 国产美女精品视频免费播放软件| 夜夜精品视频| 91成人超碰| 久久国产毛片| 日韩成人亚洲| 日韩电影免费网站| 久久久久久婷| 国产欧美亚洲一区|