Re: Big Update/DML
Date: Wed, 26 Aug 2020 22:06:35 +0000 (UTC)
Message-ID: <2145065866.6724920.1598479595274_at_mail.yahoo.com>
Tim
Thanks for the comment. Let me check these papers.
TxSanjay
On Wednesday, August 26, 2020, 11:15:56 AM EDT, Tim Gorman <tim.evdbt_at_gmail.com> wrote:
If you've got the patience, I offer a video HERE entitled "The Fastest UPDATE Is An INSERT" from Oak Table World 2012. If you prefer to read presentations or white papers instead of videos, then HERE and HERE cover much of the same topic, though not directly geared toward optimizing UPDATE operations as the video.
If you're lucky, those big tables that you want to update are partitioned already, and so you can just test and run the correction from partition to partition, a bit at a time.
If you're unlucky, those big tables that you want to update are not partitioned, so here is your chance to correct that, to create a new partitioned table, besides correcting the data errors.
The first time I used this technique, with Oracle 8.0 back in 1997, we updated a few columns on a multi-billion row range-partitioned table in a single afternoon, including dreaming it up and testing first.
On 8/26/2020 7:30 AM, Reen, Elizabeth (Redacted sender elizabeth.reen for DMARC) wrote:
#yiv1795186560 #yiv1795186560 -- _filtered {} _filtered {}#yiv1795186560 #yiv1795186560 p.yiv1795186560MsoNormal, #yiv1795186560 li.yiv1795186560MsoNormal, #yiv1795186560 div.yiv1795186560MsoNormal {margin:0in;margin-bottom:.0001pt;font-size:12.0pt;font-family:New serif;}#yiv1795186560 a:link, #yiv1795186560 span.yiv1795186560MsoHyperlink {color:#0563C1;text-decoration:underline;}#yiv1795186560 a:visited, #yiv1795186560 span.yiv1795186560MsoHyperlinkFollowed {color:#954F72;text-decoration:underline;}#yiv1795186560 p.yiv1795186560msonormal0, #yiv1795186560 li.yiv1795186560msonormal0, #yiv1795186560 div.yiv1795186560msonormal0 {margin-right:0in;margin-left:0in;font-size:12.0pt;font-family:New serif;}#yiv1795186560 span.yiv1795186560EmailStyle18 {font-family:sans-serif;color:#1F497D;}#yiv1795186560 .yiv1795186560MsoChpDefault {font-size:10.0pt;} _filtered {}#yiv1795186560 div.yiv1795186560WordSection1 {}#yiv1795186560 _filtered {}#yiv1795186560 ol {margin-bottom:0in;}#yiv1795186560 ul {margin-bottom:0in;}#yiv1795186560 Be careful with how you do parallelism. Done correctly it will speed things up. Done incorrectly and you will have a locking nightmare. Are you updating the columns with the same value? If so, the default value option might be very useful.
Liz
From: [freelists.org] oracle-l-bounce_at_freelists.org <oracle-l-bounce_at_freelists.org> On Behalf Of [freelists.org] Sanjay Mishra
Sent: Tuesday, August 25, 2020 11:29 PM
To: oracle-l_at_freelists.org
Subject: Big Update/DML
Hi Everyone
I am working on 19c and need to do one time update on multiple tables containing 3-4 Billions records and some tables are Compressed for OLTP and some are uncompressed. Tables have multiple columns but updating only one new column added with data from another column from the same table. Environment is on Exadata with Buffer Cache of 60G and CPU_count of 30
Update using high Parallel DMl enabled are taking several hours to even a day per table and are using high UNDO
- Does dropping index even the column updated has no relation to Indexed column can help the Elapsed time
- Does Compress table will help in this scenario vs uncompressed Table. Table size with compress for OLTP is around 800G and same kind of another table is 4 Tb without compression. Trying to see that if compression can help in using less IO or buffer cache from both Table and Index perspective
- Does adding more SGA or CPU can help in allocating more Parallel threads to reduce the Elapsed time
I was checking and found that dbms_parallel_execute can be good solution. Can someone update if they had used for Big Update and can share his sample code to try
TIA Sanjay
-- http://www.freelists.org/webpage/oracle-lReceived on Thu Aug 27 2020 - 00:06:35 CEST