﻿{"id":1638,"date":"2019-07-23T11:18:06","date_gmt":"2019-07-23T03:18:06","guid":{"rendered":"http:\/\/www.llku.com\/?p=1638"},"modified":"2019-07-23T11:18:06","modified_gmt":"2019-07-23T03:18:06","slug":"oracle-insert-append-%e6%8f%90%e9%ab%98%e6%80%a7%e8%83%bd","status":"publish","type":"post","link":"https:\/\/www.llku.com\/?p=1638","title":{"rendered":"ORACLE-insert \/*+append*\/\u63d0\u9ad8\u6027\u80fd"},"content":{"rendered":"<p>\u5728\u975e\u5f52\u6863\u6a21\u5f0f\u4e0b\u8868\u8bbe\u7f6e\u4e3anologging\u7528insert \/*+append*\/\u901f\u5ea6\u6700\u5feb\u3002\u90a3\u4e3a\u4ec0\u4e48\u5feb\u5462\uff0c\u539f\u7406\u662f\u4ec0\u4e48\uff1f\u4e0b\u9762\u6211\u4eec\u6765\u4e00\u8d77\u505a\u4e00\u4e2a\u5b9e\u9a8c\uff1a<\/p>\n<p>SQL&gt; create or replace view m_undo_redo as<br \/>\nselect v$statname.name,value<br \/>\nfrom v$mystat, v$statname<br \/>\nwhere v$mystat.statistic# =v$statname.statistic#<br \/>\nand (v$statname.name =&#8217;redo size&#8217;<br \/>\nor v$statname.name = &#8216;undo change vector size&#8217;);<\/p>\n<p>\u89c6\u56fe\u5df2\u521b\u5efa\u3002<\/p>\n<p>SQL&gt; create table t (x int);<\/p>\n<p>\u8868\u5df2\u521b\u5efa\u3002<\/p>\n<p>SQL&gt; set timing on<br \/>\nSQL&gt; select * from m_undo_redo;<br \/>\nNAME VALUE<br \/>\n&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;- &#8212;&#8212;&#8212;-<br \/>\nredo size 22644<br \/>\nundo change vector size 7484<br \/>\nSQL&gt; insert into t select rownum from dual connect by level &lt;=1000000;<\/p>\n<p>\u5df2\u521b\u5efa1000000\u884c\u3002<\/p>\n<p>\u5df2\u7528\u65f6\u95f4:\u00a0 00: 00: 01.03<\/p>\n<p>SQL&gt; commit;<\/p>\n<p>\u63d0\u4ea4\u5b8c\u6210\u3002<\/p>\n<p>SQL&gt; select * from m_undo_redo;<br \/>\nNAME VALUE<br \/>\n&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;- &#8212;&#8212;&#8212;-<br \/>\nredo size 15722456<br \/>\nundo change vector size 2380000<br \/>\nSQL&gt; select (2380000-7484) undo,(15722456-22644) redo from dual;<br \/>\nUNDO REDO<br \/>\n&#8212;&#8212;&#8212;- &#8212;&#8212;&#8212;-<br \/>\n2372516 15699812<br \/>\nSQL&gt; truncate table t;<\/p>\n<p>\u8868\u88ab\u622a\u65ad\u3002<\/p>\n<p>SQL&gt; select * from m_undo_redo;<br \/>\nNAME VALUE<br \/>\n&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;- &#8212;&#8212;&#8212;-<br \/>\nredo size 15781532<br \/>\nundo change vector size 2396672<br \/>\nSQL&gt; insert \/*+append*\/ into t select rownum from dual connect by level &lt;=1000000;<\/p>\n<p>\u5df2\u521b\u5efa1000000\u884c\u3002<\/p>\n<p>\u5df2\u7528\u65f6\u95f4:\u00a0 00: 00: 00.96<\/p>\n<p>SQL&gt; commit;<\/p>\n<p>\u63d0\u4ea4\u5b8c\u6210\u3002<\/p>\n<p>SQL&gt; select * from m_undo_redo;<br \/>\nNAME VALUE<br \/>\n&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;&#8212;- &#8212;&#8212;&#8212;-<br \/>\nredo size 15871640<br \/>\nundo change vector size 2419196<br \/>\nSQL&gt; select (2419196-2396672) undo,(15871640-15781532) redo from dual;<br \/>\nUNDO REDO<br \/>\n&#8212;&#8212;&#8212;- &#8212;&#8212;&#8212;-<br \/>\n22524 90108<\/p>\n<p>\u4e24\u6b21\u7684\u5bf9\u6bd4\uff1a<\/p>\n<p>\u6a21\u5f0f<br \/>\n\u751f\u6210undo<\/p>\n<p>\u751f\u6210redo<\/p>\n<p>\u666e\u901ainsert\u00a0 2372516\u00a0 15699812<br \/>\ninsert \/*+append*\/ 22524 90108<br \/>\n\u5206\u6790\u7ed3\u8bba\uff1a\u4e24\u6b21\u5bf9\u6bd4\u7684\u7ed3\u679c\u8868\u793a\u7528insert \/*+append*\/\u540e\uff0c\u6570\u636e\u7684undo\u548credo\u6ca1\u6709\u751f\u6210\u3002\u56e0\u4e3aHWM \u5728\u79fb\u52a8\u7684\u8fc7\u7a0b\u4e2d\uff0c\u8fd9\u4e9bblock\u662f\u4e0d\u80fd\u88ab\u5176\u4ed6process\u4f7f\u7528\u7684\uff0c\u90a3\u4e48\u610f\u5473\u7740\uff0c\u53ea\u8981\u8bb0\u5f55\u4e0b\u8be5\u6b21direct insert\u6240\u6d89\u53ca\u5230\u7684\u7a7a\u95f4\u7684redo \u548c undo\u00a0 \uff0c\u5728\u5931\u8d25\u56de\u6eda\u7684\u65f6\u5019\uff0c\u53ea\u9700\u8981\u628a\u8fd9\u4e9b\u7a7a\u95f4\u4fee\u6539\u4e3a\u539f\u6765\u7684\u72b6\u6001\u5c31\u53ef\u4ee5\uff0c\u800c\u4e0d\u7528\u9010\u4e2a\u8bb0\u5f55\u53bbdelete\u3002<\/p>\n<p>\u539f\u6587\uff1ahttps:\/\/blog.csdn.net\/lee_sire\/article\/details\/54098275<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u5728\u975e\u5f52\u6863\u6a21\u5f0f\u4e0b\u8868\u8bbe\u7f6e\u4e3anologging\u7528insert \/*+append*\/\u901f\u5ea6\u6700\u5feb\u3002\u90a3\u4e3a\u4ec0\u4e48\u5feb\u5462\uff0c\u539f\u7406\u662f\u4ec0 &hellip; <a href=\"https:\/\/www.llku.com\/?p=1638\" class=\"more-link\">\u7ee7\u7eed\u9605\u8bfb<span class=\"screen-reader-text\">ORACLE-insert \/*+append*\/\u63d0\u9ad8\u6027\u80fd<\/span> <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[1],"tags":[],"_links":{"self":[{"href":"https:\/\/www.llku.com\/index.php?rest_route=\/wp\/v2\/posts\/1638"}],"collection":[{"href":"https:\/\/www.llku.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.llku.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.llku.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.llku.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1638"}],"version-history":[{"count":1,"href":"https:\/\/www.llku.com\/index.php?rest_route=\/wp\/v2\/posts\/1638\/revisions"}],"predecessor-version":[{"id":1639,"href":"https:\/\/www.llku.com\/index.php?rest_route=\/wp\/v2\/posts\/1638\/revisions\/1639"}],"wp:attachment":[{"href":"https:\/\/www.llku.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1638"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.llku.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1638"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.llku.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1638"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}